From 12bfde7f9a17f9f0ed94c4c709368554ec04cdba Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 25 Mar 2024 12:06:45 -0700 Subject: [PATCH 01/90] avoid using variable keys with i18n --- .../components/SetupTab/ArgInput/index.jsx | 53 ++++++++++++------- 1 file changed, 34 insertions(+), 19 deletions(-) diff --git a/workbench/src/renderer/components/SetupTab/ArgInput/index.jsx b/workbench/src/renderer/components/SetupTab/ArgInput/index.jsx index feb505848d..5cf8294ac7 100644 --- a/workbench/src/renderer/components/SetupTab/ArgInput/index.jsx +++ b/workbench/src/renderer/components/SetupTab/ArgInput/index.jsx @@ -73,6 +73,21 @@ FormLabel.propTypes = { function Feedback(props) { const { argkey, argtype, message } = props; + const { t } = useTranslation(); + const argTypeDisplayNames = { + boolean: t('boolean'), + integer: t('integer'), + csv: t('csv'), + directory: t('directory'), + file: t('file'), + freestyle_string: t('freestyle_string'), + number: t('number'), + option_string: t('option_string'), + percent: t('percent'), + raster: t('raster'), + ratio: t('ratio'), + vector: t('vector'), + }; return ( // d-block class is needed because of a bootstrap bug // https://github.com/twbs/bootstrap/issues/29439 @@ -81,7 +96,7 @@ function Feedback(props) { type="invalid" id={`${argkey}-feedback`} > - {`${i18n.t(argtype)} : ${(message)}`} + {`${argTypeDisplayNames[argtype]} : ${(message)}`} ); } @@ -147,7 +162,23 @@ export default function ArgInput(props) { } = props; let { validationMessage } = props; - const { t, i18n } = useTranslation(); + const { t } = useTranslation(); + + // Some types benefit from more descriptive placeholder text. + const argTypeDisplayNames = { + boolean: t('boolean'), + integer: t('integer'), + csv: t('csv'), + directory: t('directory'), + file: t('file'), + freestyle_string: t('text'), + number: t('number'), + option_string: t('option_string'), + percent: t('percent: a number from 0 - 100'), + raster: t('raster'), + ratio: t('ratio: a decimal from 0 - 1'), + vector: t('vector'), + }; // Occasionaly we want to force a scroll to the end of input fields // so that the most important part of a filepath is visible. @@ -206,22 +237,6 @@ export default function ArgInput(props) { ); } - // These types benefit from more descriptive placeholder text. - let placeholderText; - switch (argSpec.type) { - case 'freestyle_string': - placeholderText = t('text'); - break; - case 'percent': - placeholderText = t('percent: a number from 0 - 100'); - break; - case 'ratio': - placeholderText = t('ratio: a decimal from 0 - 1'); - break; - default: - placeholderText = t(argSpec.type); - } - let form; if (argSpec.type === 'boolean') { form = ( @@ -266,7 +281,7 @@ export default function ArgInput(props) { id={argkey} name={argkey} type="text" - placeholder={placeholderText} + placeholder={argTypeDisplayNames[argSpec.type]} value={value || ''} // empty string is handled better than `undefined` onChange={handleChange} onFocus={handleFocus} From 9dff0e6ad39b019cfda00a22f828d9455bda0c52 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 25 Mar 2024 12:28:32 -0700 Subject: [PATCH 02/90] avoid translation template variables where possible --- workbench/src/renderer/components/OpenButton/index.jsx | 7 ++----- workbench/src/renderer/components/SetupTab/index.jsx | 7 ++----- 2 files changed, 4 insertions(+), 10 deletions(-) diff --git a/workbench/src/renderer/components/OpenButton/index.jsx b/workbench/src/renderer/components/OpenButton/index.jsx index b6b392f1a3..6688466966 100644 --- a/workbench/src/renderer/components/OpenButton/index.jsx +++ b/workbench/src/renderer/components/OpenButton/index.jsx @@ -32,11 +32,8 @@ class OpenButton extends React.Component { datastack = await fetchDatastackFromFile({ filepath: data.filePaths[0] }); } catch (error) { logger.error(error); - alert( - t( - 'No InVEST model data can be parsed from the file:\n {{filepath}}', - { filepath: data.filePaths[0] } - ) + alert( // eslint-disable-line no-alert + `${t('No InVEST model data can be parsed from the file:')}\n${data.filePaths[0]}` ); return; } diff --git a/workbench/src/renderer/components/SetupTab/index.jsx b/workbench/src/renderer/components/SetupTab/index.jsx index c241dd5706..867f0124e2 100644 --- a/workbench/src/renderer/components/SetupTab/index.jsx +++ b/workbench/src/renderer/components/SetupTab/index.jsx @@ -291,15 +291,12 @@ class SetupTab extends React.Component { return; } } else { - datastack = await fetchDatastackFromFile({ filepath: filepath }); + datastack = await fetchDatastackFromFile({ filepath: filepath }); } } catch (error) { logger.error(error); alert( // eslint-disable-line no-alert - t( - 'No InVEST model data can be parsed from the file:\n {{filepath}}', - { filepath: filepath } - ) + `${t('No InVEST model data can be parsed from the file:')}\n${filepath}` ); return; } From 0223b0d0595625220031f597f9a49fe940d1c5f1 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 25 Mar 2024 13:01:07 -0700 Subject: [PATCH 03/90] add new messages into es translation files --- workbench/src/renderer/i18n/es.json | 49 ++++++++++++++++++++++------- 1 file changed, 38 insertions(+), 11 deletions(-) diff --git a/workbench/src/renderer/i18n/es.json b/workbench/src/renderer/i18n/es.json index 054829e7ec..a330691af1 100644 --- a/workbench/src/renderer/i18n/es.json +++ b/workbench/src/renderer/i18n/es.json @@ -1,4 +1,5 @@ { + "Please choose a different folder. This application does not have permission to write to folder:": "", "Download InVEST sample data": "Descargar datos de muestra de InVEST", "Cancel": "Cancelar", "Download": "Descargar", @@ -21,19 +22,26 @@ "Cancel Run": "Cancelar la ejecución", "Error: see log for details": "Error: ver el registro para más detalles", "Run Canceled": "Ejecución cancelada", + "No InVEST model data can be parsed from the file:": "", "Browse to a datastack (.json) or InVEST logfile (.txt)": "Buscar una pila de datos (.json) o un archivo de registro InVEST (.txt)", "Open": "Abrir", "User's Guide": "Guía de uso", "Frequently Asked Questions": "Preguntas frecuentes", "Save as...": "Guardar como...", "Datastack options": "Opciones de Datastack", - "Save your parameters in a JSON file. This includes thepaths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "", + "Save your parameters in a JSON file. This includes the paths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "Guarde sus parámetros en un archivo JSON. Esto incluye las rutas a los datos de entrada, pero no los datos en sí. Abra este archivo en InVEST para restaurar sus parámetros.", "Save your parameters and input data in a compressed archive. This archive contains the same JSON file produced by the \"Parameters only\" option, plus the data. You can open this file in InVEST to restore your parameters. This option is useful to copy all the necessary data to a different location.": "Guarde sus parámetros y datos de entrada en un archivo comprimido. Este archivo contiene el mismo archivo JSON producido por la opción \"Sólo parámetros\", además de los datos. Puede abrir este archivo en InVEST para restaurar sus parámetros. Esta opción es útil para copiar todos los datos necesarios en una ubicación diferente.", "Save your parameters in a python script. This includes the paths to your input data, but not the data itself. Running the python script will programmatically run the model with your parameters. Use this as a starting point for batch scripts.": "Guarde sus parámetros en un script de Python. Esto incluye las rutas a los datos de entrada, pero no los datos en sí. Al ejecutar el script de Python, el modelo se ejecutará mediante programación con sus parámetros. Utilícelo como punto de partida para scripts por lotes.", "Save": "", + "Synchronous": "", + "Threaded task management": "", + "CPUs": "", + "DEBUG": "", + "INFO": "", + "WARNING": "", + "ERROR": "", "InVEST Settings": "Configuración de InVEST", "Language": "Idioma", - "Changing this setting will refresh the app and close all tabs": "", "Logging threshold": "Umbral de registro", "Taskgraph logging threshold": "Umbral de registro del gráfico de tareas", "Taskgraph n_workers parameter": "Parámetro n_workers del gráfico de tareas", @@ -41,28 +49,45 @@ "synchronous task execution is most reliable": "la ejecución de tareas sincrónicas es la más fiable", "threaded task management: tasks execute only in the main process, using multiple threads.": "gestión de tareas por hilos: las tareas se ejecutan solo en el proceso principal, utilizando varios hilos.", "n CPUs: depending on the InVEST model, tasks may execute in parallel using up to this many processes.": "n CPUs: dependiendo del modelo de InVEST, las tareas pueden ejecutarse en paralelo utilizando hasta este número de procesos.", - "Reset to Defaults": "Valores predeterminados", "Download Sample Data": "Descargar datos de muestra", "Clear Recent Jobs": "Borrar trabajos recientes", "no invest workspaces will be deleted": "no se eliminará ningún espacio de trabajo de InVEST", - "Bounding box does not intersect at least one other:": "La caja delimitadora no se interseca al menos con otra:", + "Warning": "", + "Changing this setting will close your tabs and relaunch the app.": "", + "Change to ": "", + "Not all of the spatial layers overlap each other. Bounding box:": "", "optional": "", + "boolean": "", + "integer": "", + "csv": "", + "directory": "", + "file": "", + "freestyle_string": "", + "number": "", + "option_string": "", + "percent": "", + "raster": "", + "ratio": "", + "vector": "", "text": "texto", "percent: a number from 0 - 100": "porcentaje: un número de 0 a 100", "ratio: a decimal from 0 - 1": "tasa: un decimal de 0 - 1", "User's guide entry": "Entrada de la guía del usuario", "Only drop one file at a time.": "Solo se puede soltar un archivo a la vez.", + "Choose location to extract archive": "", + "Datastack/Logfile for {{modelName}} does not match this model.": "", "Running": "En curso", "Run": "Ejecutar", "Browse to a datastack (.json, .tgz) or InVEST logfile (.txt)": "Buscar una pila de datos (.json, .tgz) o un archivo de registro InVEST (.txt)", "Load parameters from file": "Cargar los parámetros desde un archivo", "No args to see here": "No hay argumentos que ver aquí", "version:": "", - "Copyright 2022, The Natural Capital Project": "", - "Documentation: ": "", - "Homepage: ": "", - "Project page: ": "", - "License: ": "", + "Copyright 2023, The Natural Capital Project": "", + "Documentation": "", + "Homepage": "", + "Project page": "", + "License": "", + "InVEST Trademark and Logo Use Policy": "", "Open-Source Licenses:": "", "MIT and others": "", "Please help us by reporting problems.": "", @@ -74,9 +99,11 @@ "Consider taking a screenshot of the problem.": "", "Find the log files using the button below. There may be multiple files with a \".log\" extension; please include them all.": "", "Create a post on our forum and upload these items, along with a brief description of the problem.": "", + "Save your parameters in a JSON file. This includes thepaths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "", + "Reset to Defaults": "Valores predeterminados", + "Bounding box does not intersect at least one other:": "La caja delimitadora no se interseca al menos con otra:", "InVEST": "InVEST", "Find the Workbench log files ": "Buscar los archivos de registro de Workbench", "Please help us fix this by reporting the problem. You may follow these steps:": "Por favor, ayúdenos a solucionar esto informando del problema. Puede seguir estos pasos:", - "using the button below. There may be multiple files with a \".log\" extension.": "con el botón de abajo. Puede haber varios archivos con extensión \".log\".", - "Save your parameters in a JSON file. This includes the paths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "Guarde sus parámetros en un archivo JSON. Esto incluye las rutas a los datos de entrada, pero no los datos en sí. Abra este archivo en InVEST para restaurar sus parámetros." + "using the button below. There may be multiple files with a \".log\" extension.": "con el botón de abajo. Puede haber varios archivos con extensión \".log\"." } From 218cbc9d9eb085903610171eac3241b9ff8c2340 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 25 Mar 2024 13:54:31 -0700 Subject: [PATCH 04/90] extract message catalog template and update es catalog from it --- .../locales/es/LC_MESSAGES/messages.po | 11114 +++++++++------- .../invest/internationalization/messages.pot | 2392 ++-- 2 files changed, 7792 insertions(+), 5714 deletions(-) diff --git a/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po b/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po index 6b711c4554..52f28b5cbd 100644 --- a/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po +++ b/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po @@ -1,4903 +1,6211 @@ -# Spanish translations for InVEST. -# Copyright (C) 2022 Natural Capital Project -# This file is distributed under the same license as the InVEST project. -# FIRST AUTHOR , 2022. -# -msgid "" -msgstr "" -"Project-Id-Version: InVEST 3.12\n" -"Report-Msgid-Bugs-To: natcap-software@lists.stanford.edu\n" -"POT-Creation-Date: 2022-10-21 13:17-0700\n" -"PO-Revision-Date: 2022-11-19 17:42-0500\n" -"Last-Translator: Patricio Mena pamv59@gmail.com\n" -"Language-Team: es \n" -"Language: es\n" -"MIME-Version: 1.0\n" -"Content-Type: text/plain; charset=utf-8\n" -"Content-Transfer-Encoding: 8bit\n" -"Plural-Forms: nplurals=2; plural=(n != 1);\n" -"Generated-By: Babel 2.9.1\n" -"X-Generator: Poedit 3.2\n" - -#: src/natcap/invest/annual_water_yield.py:43 -#: src/natcap/invest/forest_carbon_edge_effect.py:118 -#: src/natcap/invest/sdr/sdr.py:75 -msgid "" -"All values in this raster must have corresponding entries in the Biophysical " -"Table." -msgstr "" -"Todos los valores de este ráster deben tener sus correspondientes inputs en " -"la Tabla Biofísica." - -#: src/natcap/invest/annual_water_yield.py:54 -msgid "" -"Map of root restricting layer depth, the soil depth at which root penetration " -"is strongly inhibited because of physical or chemical characteristics." -msgstr "" -"Mapa de la profundidad de la capa restrictiva de las raíces, la profundidad " -"del suelo a la que la penetración de las raíces está fuertemente inhibida " -"debido a las características físicas o químicas." - -#: src/natcap/invest/annual_water_yield.py:58 -msgid "root restricting layer depth" -msgstr "profundidad de la capa que restringe las raíces" - -#: src/natcap/invest/annual_water_yield.py:68 -msgid "" -"Map of plant available water content, the fraction of water that can be stored " -"in the soil profile that is available to plants." -msgstr "" -"Mapa del contenido de agua disponible para las plantas, la fracción de agua " -"que puede almacenarse en el perfil del suelo y que está disponible para las " -"plantas." - -#: src/natcap/invest/annual_water_yield.py:72 -msgid "plant available water content" -msgstr "contenido de agua disponible de la planta" - -#: src/natcap/invest/annual_water_yield.py:84 -msgid "Unique identifier for each watershed." -msgstr "Identificador único para cada cuenca hidrográfica." - -#: src/natcap/invest/annual_water_yield.py:88 -msgid "" -"Map of watershed boundaries, such that each watershed drains to a point of " -"interest where hydropower production will be analyzed." -msgstr "" -"Mapa de los límites de las cuencas hidrográficas, de forma que cada cuenca " -"drene a un punto de interés en el que se analizará la producción " -"hidroeléctrica." - -#: src/natcap/invest/annual_water_yield.py:92 src/natcap/invest/ndr/ndr.py:72 -msgid "watersheds" -msgstr "cuencas hidrográficas" - -#: src/natcap/invest/annual_water_yield.py:100 -msgid "Unique identifier for each subwatershed." -msgstr "Identificador único para cada subcuenca." - -#: src/natcap/invest/annual_water_yield.py:105 -msgid "" -"Map of subwatershed boundaries within each watershed in the Watersheds map." -msgstr "" -"Mapa de los límites de las subcuencas dentro de cada cuenca hidrográfica en el " -"mapa de cuencas." - -#: src/natcap/invest/annual_water_yield.py:108 -msgid "sub-watersheds" -msgstr "subcuencas" - -#: src/natcap/invest/annual_water_yield.py:115 -msgid "LULC code corresponding to values in the LULC map." -msgstr "Código LULC correspondiente a los valores del mapa LULC." - -#: src/natcap/invest/annual_water_yield.py:120 -msgid "" -"Code indicating whether the the LULC class is vegetated for the purpose of " -"AET. Enter 1 for all vegetated classes except wetlands, and 0 for all other " -"classes, including wetlands, urban areas, water bodies, etc." -msgstr "" -"Código que indica si la clase LULC tiene vegetación a efectos de la ETR. " -"Introduzca 1 para todas las clases con vegetación, excepto los humedales, y 0 " -"para todas las demás clases, incluidos los humedales, las zonas urbanas, las " -"masas de agua, etc." - -#: src/natcap/invest/annual_water_yield.py:130 -msgid "" -"Maximum root depth for plants in this LULC class. Only used for classes with a " -"'lulc_veg' value of 1." -msgstr "" -"Profundidad máxima de las raíces de las plantas de esta clase LULC. Solo se " -"utiliza para las clases con un valor 'lulc_veg' de 1." - -#: src/natcap/invest/annual_water_yield.py:137 -#: src/natcap/invest/urban_cooling_model.py:66 -msgid "Crop coefficient for this LULC class." -msgstr "Coeficiente de cultivo para esta clase de LULC." - -#: src/natcap/invest/annual_water_yield.py:139 -msgid "" -"Table of biophysical parameters for each LULC class. All values in the LULC " -"raster must have corresponding entries in this table." -msgstr "" -"Tabla de parámetros biofísicos para cada clase LULC. Todos los valores del " -"ráster LULC deben tener los inputs correspondientes en esta tabla." - -#: src/natcap/invest/annual_water_yield.py:143 -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:205 -#: src/natcap/invest/forest_carbon_edge_effect.py:114 -#: src/natcap/invest/ndr/ndr.py:123 src/natcap/invest/pollination.py:121 -#: src/natcap/invest/sdr/sdr.py:111 -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:140 -#: src/natcap/invest/urban_cooling_model.py:56 -#: src/natcap/invest/urban_flood_risk_mitigation.py:74 -msgid "biophysical table" -msgstr "tabla biofísica" - -#: src/natcap/invest/annual_water_yield.py:149 -msgid "" -"The seasonality factor, representing hydrogeological characterisitics and the " -"seasonal distribution of precipitation. Values typically range from 1 - 30." -msgstr "" -"El factor de estacionalidad, que representa las características " -"hidrogeológicas y la distribución estacional de las precipitaciones. Los " -"valores oscilan típicamente entre 1 y 30." - -#: src/natcap/invest/annual_water_yield.py:153 -msgid "z parameter" -msgstr "parámetro z" - -#: src/natcap/invest/annual_water_yield.py:159 src/natcap/invest/stormwater.py:51 -msgid "LULC code corresponding to the LULC raster" -msgstr "Código LULC correspondiente al ráster LULC" - -#: src/natcap/invest/annual_water_yield.py:163 -msgid "Average consumptive water use in this LULC class." -msgstr "Uso consuntivo promedio del agua en esta clase de LULC." - -#: src/natcap/invest/annual_water_yield.py:170 -msgid "" -"A table of water demand for each LULC class. Each LULC code in the LULC raster " -"must have a corresponding row in this table." -msgstr "" -"Una tabla de demanda de agua para cada clase LULC. Cada código LULC en el " -"raster LULC debe tener una fila correspondiente en esta tabla." - -#: src/natcap/invest/annual_water_yield.py:174 -msgid "water demand table" -msgstr "tabla de demanda de agua" - -#: src/natcap/invest/annual_water_yield.py:181 -msgid "" -"Unique identifier for the hydropower station. This must match the 'ws_id' " -"value for the corresponding watershed in the Watersheds vector. Each watershed " -"in the Watersheds vector must have its 'ws_id' entered in this column." -msgstr "" -"Identificador único de la central hidroeléctrica. Debe coincidir con el valor " -"\"ws_id\" de la cuenca hidrográfica correspondiente en el vector \"Watersheds" -"\". Cada cuenca hidrográfica del vector Cuencas Hidrográficas debe tener su " -"\"ws_id\" introducido en esta columna." - -#: src/natcap/invest/annual_water_yield.py:190 -msgid "" -"Turbine efficiency, the proportion of potential energy captured and converted " -"to electricity by the turbine." -msgstr "" -"Eficiencia de la turbina, la proporción de energía potencial captada y " -"convertida en electricidad por la turbina." - -#: src/natcap/invest/annual_water_yield.py:197 -msgid "The proportion of inflow water volume that is used to generate energy." -msgstr "" -"La proporción del volumen de agua de entrada que se utiliza para generar " -"energía." - -#: src/natcap/invest/annual_water_yield.py:204 -msgid "" -"The head, measured as the average annual effective height of water behind each " -"dam at the turbine intake." -msgstr "" -"La cabeza, medida como la altura media anual efectiva del agua detrás de cada " -"represa en la toma de la turbina." - -# In these cases I don´t know if I should translate the column names. In general I have used the Needs work button in all cases where there is doubt about the need to translate certain coded terms. -#: src/natcap/invest/annual_water_yield.py:212 -#, fuzzy -msgid "" -"The price of power produced by the station. Must be in the same currency used " -"in the 'cost' column." -msgstr "" -"El precio de la energía producida por la estación. Debe estar en la misma " -"moneda utilizada en la columna \"costo\"." - -#: src/natcap/invest/annual_water_yield.py:219 -msgid "" -"Annual maintenance and operations cost of running the hydropower station. Must " -"be in the same currency used in the 'kw_price' column." -msgstr "" -"Costo anual de mantenimiento y explotación de la central hidroeléctrica. Debe " -"estar en la misma moneda utilizada en la columna \"kw_price\"." - -#: src/natcap/invest/annual_water_yield.py:227 -msgid "" -"Number of years over which to value the hydropower station. This is either the " -"station's expected lifespan or the duration of the land use scenario of " -"interest." -msgstr "" -"Número de años a lo largo de los cuales valorar la central hidroeléctrica. Se " -"trata de la vida útil prevista de la central o de la duración del escenario de " -"uso del suelo de interés." - -#: src/natcap/invest/annual_water_yield.py:235 -msgid "The annual discount rate, applied for each year in the time span." -msgstr "La tasa de descuento anual, aplicada para cada año del período." - -#: src/natcap/invest/annual_water_yield.py:241 -msgid "" -"A table mapping each watershed to the associated valuation parameters for its " -"hydropower station." -msgstr "" -"Una tabla que relaciona cada cuenca con los parámetros de valoración asociados " -"a su central hidroeléctrica." - -#: src/natcap/invest/annual_water_yield.py:244 -msgid "hydropower valuation table" -msgstr "tabla de valoración hidroeléctrica" - -#: src/natcap/invest/carbon.py:38 -msgid "" -"A map of LULC for the current scenario. All values in this raster must have " -"corresponding entries in the Carbon Pools table." -msgstr "" -"Un mapa de LULC para el escenario actual. Todos los valores de este ráster " -"deben tener los inputs correspondientes en la tabla de reservas de carbono." - -#: src/natcap/invest/carbon.py:42 -msgid "current LULC" -msgstr "LULC actual" - -#: src/natcap/invest/carbon.py:47 -msgid "" -"Run sequestration analysis. This requires inputs of LULC maps for both current " -"and future scenarios. Required if REDD scenario analysis or run valuation " -"model is selected." -msgstr "" -"Ejecutar el análisis de secuestración. Esto requiere la introducción de mapas " -"LULC para los escenarios actuales y futuros. Es necesario si se selecciona el " -"análisis del escenario REDD o la ejecución del modelo de valoración." - -#: src/natcap/invest/carbon.py:52 -msgid "calculate sequestration" -msgstr "calcular la secuestración" - -#: src/natcap/invest/carbon.py:59 -#, fuzzy -msgid "" -"A map of LULC for the future scenario. If run valuation model is selected, " -"this should be the reference, or baseline, future scenario against which to " -"compare the REDD policy scenario. All values in this raster must have " -"corresponding entries in the Carbon Pools table. Required if Calculate " -"Sequestration is selected." -msgstr "" -"Un mapa de LULC para el escenario futuro. Si se selecciona el modelo de " -"ejecución de valoración, este debe ser el escenario futuro de referencia, o " -"línea de base, con el que se comparará el escenario de la política REDD. Todos " -"los valores de este ráster deben tener los inputs correspondientes en la tabla " -"de reservas de carbono. Es necesario si se selecciona la opción de calcular " -"secuestración." - -#: src/natcap/invest/carbon.py:67 -msgid "future LULC" -msgstr "LULC futuro" - -#: src/natcap/invest/carbon.py:72 -msgid "" -"Run REDD scenario analysis. This requires three LULC maps: one for the current " -"scenario, one for the future baseline scenario, and one for the future REDD " -"policy scenario." -msgstr "" -"Ejecutar el análisis del escenario REDD. Esto requiere tres mapas LULC: uno " -"para el escenario actual, otro para el escenario de referencia futuro y otro " -"para el escenario de la futura política REDD." - -#: src/natcap/invest/carbon.py:77 -msgid "REDD scenario analysis" -msgstr "Análisis del escenario REDD" - -#: src/natcap/invest/carbon.py:84 -#, fuzzy -msgid "" -"A map of LULC for the REDD policy scenario. All values in this raster must " -"have corresponding entries in the Carbon Pools table. Required if REDD " -"Scenario Analysis is selected." -msgstr "" -"Un mapa de LULC para el escenario de la política REDD. Todos los valores de " -"este ráster deben tener los inputs correspondientes en la tabla de reservas de " -"carbono. En necesario si se selecciona el análisis del escenario REDD." - -#: src/natcap/invest/carbon.py:89 -msgid "REDD LULC" -msgstr "LULC de REDD" - -#: src/natcap/invest/carbon.py:96 -msgid "" -"LULC code. Every value in the LULC maps must have a corresponding entry in " -"this column." -msgstr "" -"Código LULC. Cada valor de los mapas LULC debe tener su correspondiente input " -"en esta columna." - -#: src/natcap/invest/carbon.py:104 -msgid "Carbon density of aboveground biomass." -msgstr "Densidad de carbono de la biomasa aérea." - -#: src/natcap/invest/carbon.py:108 -msgid "Carbon density of belowground biomass." -msgstr "Densidad de carbono de la biomasa subterránea." - -#: src/natcap/invest/carbon.py:112 -msgid "Carbon density of soil." -msgstr "Densidad de carbono del suelo." - -#: src/natcap/invest/carbon.py:116 -msgid "Carbon density of dead matter." -msgstr "Densidad de carbono de la materia muerta." - -#: src/natcap/invest/carbon.py:118 -msgid "A table that maps each LULC code to carbon pool data for that LULC type." -msgstr "" -"Una tabla que mapea cada código LULC con los datos de la reserva de carbono " -"para ese tipo LULC." - -#: src/natcap/invest/carbon.py:121 -msgid "carbon pools" -msgstr "reservas de carbono" - -#: src/natcap/invest/carbon.py:128 -#, fuzzy -msgid "" -"The calendar year of the current scenario depicted in the current LULC map. " -"Required if Run Valuation model is selected." -msgstr "" -"El año calendario del escenario actual representado en el mapa LULC actual. Es " -"necesario si se selecciona el modelo de ejecución de valoración." - -#: src/natcap/invest/carbon.py:131 -msgid "current LULC year" -msgstr "año LULC actual" - -#: src/natcap/invest/carbon.py:138 -#, fuzzy -msgid "" -"The calendar year of the future scenario depicted in the future LULC map. " -"Required if Run Valuation model is selected." -msgstr "" -"El año natural del escenario futuro representado en el mapa LULC futuro. Es " -"necesario si se selecciona el modelo de ejecución de valoración." - -#: src/natcap/invest/carbon.py:146 -msgid "" -"Calculate net present value for the future scenario, and the REDD scenario if " -"provided, and report it in the final HTML document." -msgstr "" -"Calcule el valor actual neto para el escenario futuro, y el escenario REDD si " -"se proporciona, e infórmelo en el documento HTML final." - -#: src/natcap/invest/carbon.py:150 -msgid "run valuation model" -msgstr "correr el modelo de valoración" - -#: src/natcap/invest/carbon.py:156 -#, fuzzy -msgid "The present value of carbon. Required if Run Valuation model is selected." -msgstr "" -"El valor actual del carbono. Se necesita si se selecciona el modelo de " -"ejecución de valoración." - -#: src/natcap/invest/carbon.py:159 -msgid "price of carbon" -msgstr "precio del carbono" - -#: src/natcap/invest/carbon.py:164 -#, fuzzy -msgid "" -"The annual market discount rate in the price of carbon, which reflects " -"society's preference for immediate benefits over future benefits. Required if " -"Run Valuation model is selected." -msgstr "" -"La tasa de descuento anual del mercado en el precio del carbono, que refleja " -"la preferencia de la sociedad por los beneficios inmediatos frente a los " -"futuros. Requerido si se selecciona el modelo de ejecución de valoración." - -#: src/natcap/invest/carbon.py:169 -msgid "annual market discount rate" -msgstr "tasa de descuento anual de mercado" - -#: src/natcap/invest/carbon.py:174 -#, fuzzy -msgid "" -"The relative annual increase of the price of carbon. Required if Run Valuation " -"model is selected." -msgstr "" -"El incremento anual relativo del precio del carbono. Requerido si se " -"selecciona el modelo de ejecución de valoración." - -#: src/natcap/invest/carbon.py:177 -msgid "annual price change" -msgstr "variación anual de precios" - -#: src/natcap/invest/cli.py:57 -msgid "Available models:" -msgstr "Modelos disponibles:" - -#: src/natcap/invest/coastal_vulnerability.py:33 -msgid "Must be a polyline vector" -msgstr "Debe ser un vector polilínea" - -#: src/natcap/invest/coastal_vulnerability.py:34 -msgid "Must be a point or multipoint geometry." -msgstr "Debe ser una geometría de punto o multipunto." - -#: src/natcap/invest/coastal_vulnerability.py:60 -msgid "Map of the region over which to run the model." -msgstr "Mapa de la región sobre la que se ejecuta el modelo." - -#: src/natcap/invest/coastal_vulnerability.py:66 -msgid "Interval at which to space shore points along the coastline." -msgstr "" -"Intervalo en el que se espacian los puntos de la orilla a lo largo de la línea " -"de costa." - -#: src/natcap/invest/coastal_vulnerability.py:68 -msgid "model resolution" -msgstr "resolución del modelo" - -#: src/natcap/invest/coastal_vulnerability.py:74 -msgid "" -"Map of all landmasses in and around the region of interest. It is not " -"recommended to clip this landmass to the AOI polygon because some functions in " -"the model require searching for landmasses around shore points up to the " -"distance defined in Maximum Fetch Distance, which likely extends beyond the " -"AOI polygon." -msgstr "" -"Mapa de todas las masas de tierra en y alrededor de la región de interés. No " -"se recomienda recortar esta masa de tierra al polígono ADI porque algunas " -"funciones en el modelo requieren la búsqueda de masas de tierra alrededor de " -"los puntos de la costa hasta la distancia definida en la distancia máxima de " -"búsqueda, que probablemente se extiende más allá del polígono AOI." - -#: src/natcap/invest/coastal_vulnerability.py:81 -msgid "landmasses" -msgstr "masas de tierra" - -# In all this there is some coding error I don´t get. The translation itself is correct. -#: src/natcap/invest/coastal_vulnerability.py:88 -#, python-format -msgid "" -"Proportion of the highest 10% of wind speeds in the record of interest that " -"blow in the direction of each sector." -msgstr "" -"Proporción del 10% más alto de las velocidades de viento en el registro de " -"interés que soplan en la dirección de cada sector." - -#: src/natcap/invest/coastal_vulnerability.py:95 -#, python-format -msgid "" -"Average of the highest 10% of wind speeds that blow in the direction of each " -"sector." -msgstr "" -"Promedio del 10% más alto de las velocidades de viento que soplan en la " -"dirección de cada sector." - -#: src/natcap/invest/coastal_vulnerability.py:100 -#, python-format -msgid "" -"Proportion of the highest 10% of wave power values on record that are in each " -"sector." -msgstr "" -"Proporción del 10% más alto de los valores de potencia de olas registrados que " -"se encuentran en cada sector." - -#: src/natcap/invest/coastal_vulnerability.py:106 -#, python-format -msgid "" -"Average of the highest 10% of wave power values on record in the direction of " -"each sector." -msgstr "" -"Promedio del 10% más alto de valores de potencia de olas registrados en la " -"dirección de cada sector." - -#: src/natcap/invest/coastal_vulnerability.py:111 -#, fuzzy, python-format -msgid "" -"Average of the highest 10% of wind speeds that are centered on each main " -"sector direction X." -msgstr "" -"Promedio del 10% más alto de velocidades de viento centradas en cada dirección " -"X de sector principal." - -#: src/natcap/invest/coastal_vulnerability.py:116 -msgid "" -"Map of gridded wind and wave data that represent storm conditions. This global " -"dataset is provided with the InVEST sample data. There are 80 required " -"columns; each of the 5 types is repeated for each sixteenth sector of the 360° " -"compass: [0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For " -"example: REI_PCT0, V10PCT_90." -msgstr "" -"Mapa de datos cuadriculados de viento y oleaje que representan las condiciones " -"de las tormentas. Este conjunto de datos globales se proporciona con los datos " -"de muestra de InVEST. Hay 80 columnas necesarias; cada uno de los 5 tipos se " -"repite para cada decimosexto sector de la brújula de 360°: " -"[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. Por ejemplo " -"REI_PCT0, V10PCT_90." - -#: src/natcap/invest/coastal_vulnerability.py:124 -msgid "WaveWatchIII" -msgstr "WaveWatchIII" - -#: src/natcap/invest/coastal_vulnerability.py:130 -msgid "" -"Maximum distance in meters to extend rays from shore points. Points with rays " -"equal to this distance accumulate ocean- driven wave exposure along those rays " -"and local-wind-driven wave exposure along the shorter rays." -msgstr "" -"Distancia máxima en metros para extender los rayos desde los puntos de la " -"costa. Los puntos con rayos iguales a esta distancia acumulan la exposición a " -"las olas impulsadas por el océano a lo largo de esos rayos y la exposición a " -"las olas impulsadas por el viento local a lo largo de los rayos más cortos." - -#: src/natcap/invest/coastal_vulnerability.py:135 -msgid "maximum fetch distance" -msgstr "distancia máxima de alcance" - -#: src/natcap/invest/coastal_vulnerability.py:143 -msgid "" -"Map of bathymetry (ocean depth). Bathymetry values should be negative, and any " -"positive values will be ignored. This should cover the area extending beyond " -"the AOI to the maximum fetch distance." -msgstr "" -"Mapa de batimetría (profundidad del océano). Los valores de la batimetría " -"deben ser negativos, y cualquier valor positivo será ignorado. Debe abarcar la " -"zona que se extiende más allá del ADI hasta la distancia máxima de alcance." - -#: src/natcap/invest/coastal_vulnerability.py:149 -msgid "Bathymetry" -msgstr "Batimetría" - -#: src/natcap/invest/coastal_vulnerability.py:155 -msgid "" -"Map of the edges of the continental shelf or other locally relevant bathymetry " -"contour." -msgstr "" -"Mapa de los bordes de la plataforma continental u otro contorno batimétrico " -"localmente relevante." - -#: src/natcap/invest/coastal_vulnerability.py:158 -msgid "continental shelf contour" -msgstr "contorno de la plataforma continental" - -#: src/natcap/invest/coastal_vulnerability.py:166 -msgid "" -"Map of elevation above sea level on land. This should cover the area extending " -"beyond the AOI by at least the elevation averaging radius. Elevation may be " -"measured in any unit." -msgstr "" -"Mapa de elevación sobre el nivel del mar en tierra. Debe cubrir el área que se " -"extiende más allá del ADI por lo menos el radio de promedio de elevación. La " -"elevación puede medirse en cualquier unidad." - -#: src/natcap/invest/coastal_vulnerability.py:175 -msgid "" -"A radius around each shore point within which to average the elevation values " -"in the DEM raster." -msgstr "" -"Un radio alrededor de cada punto de la costa dentro del cual se promedian los " -"valores de elevación en el ráster MDE." - -#: src/natcap/invest/coastal_vulnerability.py:178 -msgid "elevation averaging radius" -msgstr "radio de promedio de elevación" - -#: src/natcap/invest/coastal_vulnerability.py:185 -msgid "Unique name for the habitat. No spaces allowed." -msgstr "Nombre único para el hábitat. No se permiten espacios." - -#: src/natcap/invest/coastal_vulnerability.py:191 -msgid "" -"Map of area(s) where the habitat is present. If raster, presence of the " -"habitat can be represented by any value and absence of the habitat can be " -"represented by 0 and nodata values." -msgstr "" -"Mapa de la(s) zona(s) donde está presente el hábitat. Si se trata de un " -"raster, la presencia del hábitat puede representarse con cualquier valor y la " -"ausencia del hábitat puede representarse con valores 0 y nodata." - -#: src/natcap/invest/coastal_vulnerability.py:199 -msgid "very high protection" -msgstr "protección muy alta" - -#: src/natcap/invest/coastal_vulnerability.py:200 -msgid "high protection" -msgstr "protección alta" - -#: src/natcap/invest/coastal_vulnerability.py:201 -msgid "moderate protection" -msgstr "protección moderada" - -#: src/natcap/invest/coastal_vulnerability.py:202 -msgid "low protection" -msgstr "protección baja" - -#: src/natcap/invest/coastal_vulnerability.py:203 -msgid "very low protection" -msgstr "protección muy baja" - -#: src/natcap/invest/coastal_vulnerability.py:205 -msgid "Relative amount of coastline protection this habitat provides." -msgstr "" -"Cantidad relativa de protección de la línea de costa que proporciona este " -"hábitat." - -#: src/natcap/invest/coastal_vulnerability.py:213 -msgid "" -"The distance beyond which this habitat will provide no protection to the " -"coastline." -msgstr "" -"La distancia más allá de la cual este hábitat no proporcionará ninguna " -"protección a la línea de costa." - -#: src/natcap/invest/coastal_vulnerability.py:218 -msgid "Table that specifies spatial habitat data and parameters." -msgstr "Tabla que especifica los datos y parámetros espaciales del hábitat." - -#: src/natcap/invest/coastal_vulnerability.py:220 -msgid "habitats table" -msgstr "tabla de hábitats" - -#: src/natcap/invest/coastal_vulnerability.py:228 -msgid "very low exposure" -msgstr "exposición muy baja" - -#: src/natcap/invest/coastal_vulnerability.py:229 -msgid "low exposure" -msgstr "exposición baja" - -#: src/natcap/invest/coastal_vulnerability.py:230 -msgid "moderate exposure" -msgstr "exposición moderada" - -#: src/natcap/invest/coastal_vulnerability.py:231 -msgid "high exposure" -msgstr "exposición alta" - -#: src/natcap/invest/coastal_vulnerability.py:232 -msgid "very high exposure" -msgstr "exposición muy alta" - -#: src/natcap/invest/coastal_vulnerability.py:234 -msgid "Relative exposure of the segment of coastline." -msgstr "Exposición relativa del segmento de costa." - -#: src/natcap/invest/coastal_vulnerability.py:239 -msgid "Map of relative exposure of each segment of coastline." -msgstr "Mapa de la exposición relativa de cada segmento de costa." - -#: src/natcap/invest/coastal_vulnerability.py:240 -msgid "geomorphology" -msgstr "geomorfología" - -#: src/natcap/invest/coastal_vulnerability.py:245 -msgid "1: very low exposure" -msgstr "1: exposición muy baja" - -#: src/natcap/invest/coastal_vulnerability.py:246 -msgid "2: low exposure" -msgstr "2: exposición baja" - -#: src/natcap/invest/coastal_vulnerability.py:247 -msgid "3: moderate exposure" -msgstr "3: exposición moderada" - -#: src/natcap/invest/coastal_vulnerability.py:248 -msgid "4: high exposure" -msgstr "4: exposición alta" - -#: src/natcap/invest/coastal_vulnerability.py:249 -msgid "5: very high exposure" -msgstr "5: exposición muy alta" - -#: src/natcap/invest/coastal_vulnerability.py:252 -msgid "" -"Exposure rank to assign to any shore points that are not near to any segment " -"in the geomorphology vector. Required if a Geomorphology vector is provided." -msgstr "" -"Rango de exposición para asignar a cualquier punto de la costa que no esté " -"cerca de ningún segmento en el vector geomorfológico. Es necesario si se " -"proporciona un vector geomorfológico." - -#: src/natcap/invest/coastal_vulnerability.py:256 -msgid "geomorphology fill value" -msgstr "valor de relleno geomorfológico" - -#: src/natcap/invest/coastal_vulnerability.py:264 -msgid "Map of total human population on each pixel." -msgstr "Mapa de la población humana total en cada píxel." - -#: src/natcap/invest/coastal_vulnerability.py:265 -msgid "human population" -msgstr "población humana" - -#: src/natcap/invest/coastal_vulnerability.py:272 -msgid "" -"The radius around each shore point within which to compute the average " -"population density. Required if a Human Population map is provided." -msgstr "" -"El radio alrededor de cada punto de la costa dentro del cual se calcula la " -"densidad media de población. Es necesario si se proporciona un mapa de " -"población humana." - -#: src/natcap/invest/coastal_vulnerability.py:276 -msgid "population search radius" -msgstr "radio de búsqueda de la población" - -#: src/natcap/invest/coastal_vulnerability.py:282 -msgid "" -"Sea level rise rate or amount. This field name must be chosen as the Sea Level " -"Rise Field." -msgstr "" -"Tasa o cantidad de aumento del nivel del mar. Este nombre de campo debe " -"elegirse como campo de aumento del nivel del mar." - -#: src/natcap/invest/coastal_vulnerability.py:291 -msgid "" -"Map of sea level rise rates or amounts. May be any sea level rise metric of " -"interest, such as rate, or net rise/fall." -msgstr "" -"Mapa de las tasas o cantidades de aumento del nivel del mar. Puede ser " -"cualquier métrica de aumento del nivel del mar de interés, como la tasa o el " -"aumento/descenso neto." - -#: src/natcap/invest/coastal_vulnerability.py:294 -msgid "sea level rise" -msgstr "aumento del nivel del mar" - -#: src/natcap/invest/coastal_vulnerability.py:300 -msgid "" -"Name of the field in the sea level rise vector which contains the sea level " -"rise metric of interest. Required if a Sea Level Rise vector is provided." -msgstr "" -"Nombre del campo del vector de aumento del nivel del mar que contiene la " -"métrica de aumento del nivel del mar de interés. Es obligatorio si se " -"proporciona un vector de aumento del nivel del mar." - -#: src/natcap/invest/coastal_vulnerability.py:304 -msgid "sea level rise field" -msgstr "campo de aumento del nivel del mar" - -#: src/natcap/invest/crop_production_percentile.py:96 -msgid "" -"A table that maps each LULC code from the LULC map to one of the 175 canonical " -"crop names representing the crop grown in that LULC class." -msgstr "" -"Una tabla que asigna cada código LULC del mapa LULC a uno de los 175 nombres " -"de cultivos canónicos que representan el cultivo realizado en esa clase LULC." - -#: src/natcap/invest/crop_production_percentile.py:100 -msgid "LULC to Crop Table" -msgstr "Tabla de LULC a cultivos" - -#: src/natcap/invest/crop_production_percentile.py:112 -msgid "Table mapping each climate bin to yield percentiles for each crop." -msgstr "" -"Tabla que relaciona cada casilla climática con los percentiles de rendimiento " -"de cada cultivo." - -#: src/natcap/invest/crop_production_percentile.py:142 -msgid "Maps of climate bins for each crop." -msgstr "Mapas de los intervalos climáticos para cada cultivo." - -#: src/natcap/invest/crop_production_percentile.py:152 -msgid "Maps of actual observed yield for each crop." -msgstr "Mapas de rendimiento real observado para cada cultivo." - -#: src/natcap/invest/crop_production_percentile.py:207 -msgid "Path to the InVEST Crop Production Data directory." -msgstr "" -"Ruta de acceso al directorio de datos de producción de cultivos de InVEST." - -#: src/natcap/invest/crop_production_percentile.py:208 -msgid "model data directory" -msgstr "directorio de datos del modelo" - -#: src/natcap/invest/crop_production_regression.py:23 -msgid "barley" -msgstr "cebada" - -#: src/natcap/invest/crop_production_regression.py:24 -msgid "maize" -msgstr "maíz" - -#: src/natcap/invest/crop_production_regression.py:25 -msgid "oil palm" -msgstr "palma aceitera" - -#: src/natcap/invest/crop_production_regression.py:26 -msgid "potato" -msgstr "papa" - -#: src/natcap/invest/crop_production_regression.py:27 -msgid "rice" -msgstr "arroz" - -#: src/natcap/invest/crop_production_regression.py:28 -msgid "soybean" -msgstr "soya" - -#: src/natcap/invest/crop_production_regression.py:29 -msgid "sugar beet" -msgstr "remolacha azucarera" - -#: src/natcap/invest/crop_production_regression.py:30 -msgid "sugarcane" -msgstr "caña de azúcar" - -#: src/natcap/invest/crop_production_regression.py:31 -msgid "wheat" -msgstr "trigo" - -#: src/natcap/invest/crop_production_regression.py:61 -msgid "" -"A table that maps each LULC code from the LULC map to one of the 10 canonical " -"crop names representing the crop grown in that LULC class." -msgstr "" -"Una tabla que asigna cada código LULC del mapa LULC a uno de los 10 nombres de " -"cultivos canónicos que representan el cultivo realizado en esa clase LULC." - -#: src/natcap/invest/crop_production_regression.py:65 -msgid "LULC to crop table" -msgstr "Tabla de LULC a cultivos" - -#: src/natcap/invest/crop_production_regression.py:73 -msgid "One of the supported crop types." -msgstr "Uno de los tipos de cultivo admitidos." - -#: src/natcap/invest/crop_production_regression.py:81 -msgid "A table that maps crops to fertilizer application rates." -msgstr "" -"Una tabla que relaciona los cultivos con las tasas de aplicación de " -"fertilizantes." - -#: src/natcap/invest/crop_production_regression.py:83 -msgid "fertilization rate table" -msgstr "tabla de tasas de fertilización" - -#: src/natcap/invest/crop_production_regression.py:156 -msgid "The Crop Production datasets provided with the model." -msgstr "" -"Los conjuntos de datos de producción de cultivos que se proporcionan con el " -"modelo." - -#: src/natcap/invest/crop_production_regression.py:157 -msgid "model data" -msgstr "datos del modelo" - -# In this case I am not sure about translatingf the selected item. -#: src/natcap/invest/forest_carbon_edge_effect.py:50 -#, fuzzy -msgid "" -"Number of closest regression models that are used when calculating the total " -"biomass. Each local model is linearly weighted by distance such that the " -"pixel's biomass is a function of each of these points with the closest point " -"having the largest effect. Must be an integer greater than 0. Required if " -"Compute Forest Edge Effects is selected." -msgstr "" -"Número de modelos de regresión más cercanos que se utilizan al calcular la " -"biomasa total. Cada modelo local está ponderado linealmente por la distancia, " -"de manera que la biomasa del píxel es una función de cada uno de estos puntos, " -"teniendo el punto más cercano el mayor efecto. Debe ser un número entero mayor " -"que 0. Se necesita si se selecciona el cálculo de efectos de borde de bosque." - -#: src/natcap/invest/forest_carbon_edge_effect.py:58 -msgid "number of points to average" -msgstr "número de puntos a promediar" - -#: src/natcap/invest/forest_carbon_edge_effect.py:70 -msgid "" -"Code for this LULC class from the LULC map. Every value in the LULC raster " -"must have a corresponding entry in this column." -msgstr "" -"Código de esta clase LULC del mapa LULC. Cada valor de la trama LULC debe " -"tener un input correspondiente en esta columna." - -#: src/natcap/invest/forest_carbon_edge_effect.py:76 -msgid "" -"Enter 1 if the LULC class is tropical forest, 0 if it is not tropical forest." -msgstr "" -"Introduzca 1 si la clase LULC es bosque tropical, 0 si no es bosque tropical." - -#: src/natcap/invest/forest_carbon_edge_effect.py:82 -msgid "Carbon density value for the aboveground carbon pool." -msgstr "" -"Valor de la densidad del carbono para la reserva de carbono sobre el suelo." - -#: src/natcap/invest/forest_carbon_edge_effect.py:90 -msgid "" -"Carbon density value for the belowground carbon pool. Required if calculating " -"all pools." -msgstr "" -"Valor de la densidad del carbono para la reserva de carbono subterránea. Es " -"necesario si se calculan todas las reservas." - -#: src/natcap/invest/forest_carbon_edge_effect.py:98 -msgid "" -"Carbon density value for the soil carbon pool. Required if calculating all " -"pools." -msgstr "" -"Valor de la densidad del carbono para la reserva de carbono del suelo. Es " -"necesario si se calculan todas las reservas." - -#: src/natcap/invest/forest_carbon_edge_effect.py:106 -msgid "" -"Carbon density value for the dead matter carbon pool. Required if calculating " -"all pools." -msgstr "" -"Valor de la densidad del carbono para la reserva de carbono de la materia " -"muerta. Es necesario si se calculan todas las reservas." - -#: src/natcap/invest/forest_carbon_edge_effect.py:111 -msgid "" -"A table mapping each LULC code from the LULC map to biophysical data for that " -"LULC class." -msgstr "" -"Una tabla que relaciona cada código LULC del mapa LULC con los datos " -"biofísicos de esa clase LULC." - -#: src/natcap/invest/forest_carbon_edge_effect.py:127 -msgid "all" -msgstr "todos" - -#: src/natcap/invest/forest_carbon_edge_effect.py:128 -msgid "" -"Use all pools (aboveground, belowground, soil, and dead matter) in the carbon " -"pool calculation." -msgstr "" -"Utilice todas las reservas (sobre el suelo, bajo el suelo, suelo y materia " -"muerta) en el cálculo del depósito de carbono." - -#: src/natcap/invest/forest_carbon_edge_effect.py:132 -msgid "aboveground only" -msgstr "solo en la superficie" - -#: src/natcap/invest/forest_carbon_edge_effect.py:133 -msgid "Only use the aboveground pool in the carbon pool calculation." -msgstr "" -"Solo utilice la reserva sobre el suelo en el cálculo de la reserva de carbono." - -#: src/natcap/invest/forest_carbon_edge_effect.py:137 -msgid "Which carbon pools to consider." -msgstr "Qué reservas de carbono hay que tener en cuenta." - -#: src/natcap/invest/forest_carbon_edge_effect.py:138 -msgid "carbon pools to calculate" -msgstr "reservas de carbono a calcular" - -#: src/natcap/invest/forest_carbon_edge_effect.py:142 -msgid "Account for forest edge effects on aboveground carbon." -msgstr "" -"Tanga en cuenta los efectos de los bordes del bosque sobre el carbono sobre " -"el suelo." - -#: src/natcap/invest/forest_carbon_edge_effect.py:143 -msgid "compute forest edge effects" -msgstr "calcule los efectos de los bordes del bosque" - -#: src/natcap/invest/forest_carbon_edge_effect.py:151 -msgid "asymptotic" -msgstr "asintótico" - -#: src/natcap/invest/forest_carbon_edge_effect.py:152 -msgid "logarithmic" -msgstr "logarítmico" - -#: src/natcap/invest/forest_carbon_edge_effect.py:153 -msgid "linear" -msgstr "lineal" - -#: src/natcap/invest/forest_carbon_edge_effect.py:155 -msgid "Optimal regression model for the area." -msgstr "Modelo de regresión óptimo para la zona." - -#: src/natcap/invest/forest_carbon_edge_effect.py:160 -msgid "θ₁ parameter for the regression equation." -msgstr "parámetro θ₁ para la ecuación de regresión." - -#: src/natcap/invest/forest_carbon_edge_effect.py:164 -msgid "θ₂ parameter for the regression equation." -msgstr "parámetro θ₂ para la ecuación de regresión." - -#: src/natcap/invest/forest_carbon_edge_effect.py:168 -msgid "" -"θ₃ parameter for the regression equation. Used only for the asymptotic model." -msgstr "" -"parámetro θ₃ para la ecuación de regresión. Se utiliza solamente para el " -"modelo asintótico." - -# Idem -#: src/natcap/invest/forest_carbon_edge_effect.py:174 -#, fuzzy -msgid "" -"Map storing the optimal regression model for each tropical subregion and the " -"corresponding theta parameters for that regression equation. Default data is " -"provided. Required if Compute Forest Edge Effects is selected." -msgstr "" -"Mapa que almacena el modelo de regresión óptimo para cada subregión tropical y " -"los parámetros theta correspondientes para esa ecuación de regresión. Se " -"proporcionan datos por defecto. Es necesario si se selecciona la opción de " -"calcular los efectos de los bordes del bosque." - -#: src/natcap/invest/forest_carbon_edge_effect.py:179 -msgid "global regression models" -msgstr "modelos de regresión global" - -#: src/natcap/invest/forest_carbon_edge_effect.py:184 -#, fuzzy -msgid "" -"Proportion of forest edge biomass that is elemental carbon. Required if " -"Compute Forest Edge Effects is selected." -msgstr "" -"Proporción de la biomasa del borde del bosque que es carbono elemental. Es " -"necesaria si se selecciona la opción de calcular los efectos del borde del " -"bosque." - -#: src/natcap/invest/forest_carbon_edge_effect.py:187 -msgid "forest edge biomass to carbon conversion factor" -msgstr "factor de conversión de la biomasa del borde del bosque en carbono" - -#: src/natcap/invest/globio.py:44 -msgid "Use the predefined GLOBIO LULC map instead of providing the LULC map." -msgstr "" -"Utilice el mapa LULC predefinido de GLOBIO en lugar de proporcionar el mapa " -"LULC." - -#: src/natcap/invest/globio.py:47 -msgid "use predefined LULC" -msgstr "utilizar LULC predefinidos" - -#: src/natcap/invest/globio.py:53 -#, fuzzy -msgid "" -"Each LULC code must have a corresponding entry in the biophysical table. " -"Required if Use Predefined GLOBIO LULC is not selected." -msgstr "" -"Cada código LULC debe tener un input correspondiente en la tabla biofísica. Es " -"obligatorio si no se ha seleccionado la opción de utilizar LULC GLOBIO " -"predefinido." - -#: src/natcap/invest/globio.py:63 -msgid "LULC code from the LULC map input." -msgstr "Código LULC del input del mapa LULC." - -#: src/natcap/invest/globio.py:66 -msgid "Corresponding GLOBIO LULC code." -msgstr "Código LULC GLOBIO correspondiente." - -#: src/natcap/invest/globio.py:69 -msgid "" -"A table mapping each LULC code in the LULC raster input to the corresponding " -"GLOBIO LULC code for the class. Required if Use Predefined GLOBIO LULC is not " -"selected." -msgstr "" -"Una tabla que mapea cada código LULC en el input del ráster LULC al " -"correspondiente código LULC GLOBIO para la clase. Es necesario si no se " -"selecciona la opción Usar LULC GLOBIO predefinida." - -#: src/natcap/invest/globio.py:73 -msgid "LULC to GLOBIO LULC Table" -msgstr "Tabla LULC a LULC GLOBIO " - -#: src/natcap/invest/globio.py:79 -msgid "" -"Maps of the location of infrastructure. For rasters, any valid value greater " -"than zero indicates the presence of infrastrucutre. For vectors, any " -"geometries indicate the presence of infrastructure." -msgstr "" -"Mapas de la ubicación de las infraestructuras. Para los rásters, cualquier " -"valor válido superior a cero indica la presencia de infraestructuras. Para los " -"vectores, cualquier geometría indica la presencia de infraestructuras." - -#: src/natcap/invest/globio.py:90 -msgid "" -"Directory containing raster and/or vector map(s) any forms of infrastructure " -"to consider in the MSA calculation." -msgstr "" -"Directorio que contiene mapa(s) ráster y/o vectorial(es) cualquier forma de " -"infraestructura a considerar en el cálculo de la abundancia media de especies " -"(AME)." - -#: src/natcap/invest/globio.py:93 -msgid "infrastructure directory" -msgstr "directorio de infraestructuras" - -# Not sure about translating the selected item -#: src/natcap/invest/globio.py:100 -msgid "" -"Map of the proportion of each pixel that is pasture. Required if Use " -"Predefined GLOBIO LULC is not selected." -msgstr "" -"Mapa de la proporción de cada píxel que es pasto. Es necesario si no se " -"selecciona la opción de usar LULC GLOBIO predefinido." - -#: src/natcap/invest/globio.py:103 -msgid "pasture" -msgstr "pasto" - -#: src/natcap/invest/globio.py:106 -msgid "potential vegetation" -msgstr "vegetación potencial" - -# Idem -#: src/natcap/invest/globio.py:111 -msgid "" -"Map of potential vegetation classes from Ramankutty and Foley (1999). Required " -"if Use Predefined GLOBIO LULC is not selected." -msgstr "" -"Mapa de clases de vegetación potencial de Ramankutty y Foley (1999). Es " -"necesario si no se selecciona la opción de usar LULC GLOBIO predefinido." - -# Idem -#: src/natcap/invest/globio.py:119 -msgid "" -"Areas in the Pasture map with a pasture proportion greater than or equal to " -"this threshold are considered grassland or livestock grazing areas. Required " -"if Use Predefined GLOBIO LULC is not selected." -msgstr "" -"Las áreas en el mapa de pastos con una proporción de pastos mayor o igual a " -"este umbral se consideran áreas de pastizales o de pastoreo de ganado. Es " -"obligatorio si no se selecciona la opción de utilizar LULC GLOBIO predefinido." - -#: src/natcap/invest/globio.py:124 -msgid "pasture threshold" -msgstr "umbral de pastoreo" - -#: src/natcap/invest/globio.py:128 -msgid "Proportion of total agriculture that is intensive. " -msgstr "Proporción de la agricultura total que es intensiva. " - -#: src/natcap/invest/globio.py:130 -msgid "proportion of intensified agriculture" -msgstr "proporción de agricultura intensificada" - -# Check English (ragmentation) -#: src/natcap/invest/globio.py:135 -msgid "" -"Forest ragmentation quality index threshold below which an area is classified " -"as secondary forest. Areas with FFQI greater than or equal to this threshold " -"are classified as primary forest. Required if Use Predefined GLOBIO LULC is " -"not selected." -msgstr "" -"Umbral del índice de calidad de fragmentación forestal por debajo del cual una " -"zona se clasifica como bosque secundario. Las áreas con un ICFF mayor o igual " -"a este umbral se clasifican como bosque primario. Obligatorio si no se " -"selecciona la opción de utilizar LULC GLOBIO predefinido ." - -#: src/natcap/invest/globio.py:141 -msgid "primary threshold" -msgstr "umbral primario" - -#: src/natcap/invest/globio.py:150 -msgid "" -"This MSA value represents infrastructure impacts on primary vegetation. The " -"value in the 'value' column is a distance range in meters." -msgstr "" -"Este valor AME representa los impactos de la infraestructura en la vegetación " -"primaria. El valor de la columna \"valor\" es un rango de distancia en metros." - -#: src/natcap/invest/globio.py:156 -msgid "" -"This MSA value represents infrastructure impacts on non-primary vegetation. " -"The value in the 'value' column is a distance range in meters." -msgstr "" -"Este valor AME representa los impactos de la infraestructura en la vegetación " -"no primaria. El valor de la columna \"valor\" es un rango de distancia en " -"metros." - -#: src/natcap/invest/globio.py:162 -msgid "" -"This MSA value represents fragmentation impacts. The value in the 'value' " -"column is an FFQI range." -msgstr "" -"Este valor AME representa los impactos de la fragmentación. El valor de la " -"columna \"valor\" es un rango FFQI." - -#: src/natcap/invest/globio.py:167 -msgid "" -"This MSA value represents land-use impacts. The value in the 'value' column is " -"one of the GLOBIO-recognized LULC codes." -msgstr "" -"Este valor AME representa los impactos del uso de la tierra. El valor de la " -"columna \"valor\" es uno de los códigos LULC reconocidos por GLOBIO." - -#: src/natcap/invest/globio.py:172 -msgid "The type of MSA value in this row." -msgstr "El tipo de valor AME en esta fila." - -#: src/natcap/invest/globio.py:176 -msgid "" -"Indicates a number or range of a bin. This may be a single number e.g. 1000, a " -"range (two numbers separated by a hyphen e.g. 1000-2000), or an upper or lower " -"bound (a number preceded by > or < e.g. <5" -msgstr "" -"Indica un número o un rango de una intevalo. Puede ser un solo número, por " -"ejemplo, 1000, un rango (dos números separados por un guion, por ejemplo, " -"1000-2000), o un límite superior o inferior (un número precedido por > o <, " -"por ejemplo, <5" - -#: src/natcap/invest/globio.py:184 -msgid "" -"MSA value for the MSA type specified in the 'msa_type' column, when the impact " -"value is within the range given in the 'value' column." -msgstr "" -"Valor de AME para el tipo de especificado en la columna \"msa_type\", cuando " -"el valor de impacto está dentro del rango dado en la columna \"value\"." - -#: src/natcap/invest/globio.py:189 -msgid "" -"Table that sets the MSA values for each impact driver and each range of impact " -"values." -msgstr "" -"Tabla que establece los valores AME para cada motor de impacto y cada rango de " -"valores de impacto." - -#: src/natcap/invest/globio.py:192 -msgid "MSA Parameter Table" -msgstr "Tabla de parámetros AME" - -#: src/natcap/invest/globio.py:203 -msgid "" -"Predefined GLOBIO LULC map using the standard GLOBIO classification scheme and " -"codes. Required if Use Predefined GLOBIO LULC is selected." -msgstr "" -"Mapa LULC predefinido de GLOBIO que utiliza el esquema de clasificación y los " -"códigos estándar de GLOBIO. Es necesario si se selecciona la opción de usar " -"LULC GLOBIO predefinido." - -#: src/natcap/invest/globio.py:207 -msgid "GLOBIO Classified Land Use" -msgstr "Uso del suelo clasificado por GLOBIO" - -#: src/natcap/invest/habitat_quality.py:23 -#, fuzzy -msgid "" -"Threats {threats} does not match any column in the sensitivity table. " -"Sensitivity columns: {column_names}" -msgstr "" -"Amenazas {threats} no coincide con ninguna columna de la tabla de " -"sensibilidad. Columnas de sensibilidad: {column_names}" - -#: src/natcap/invest/habitat_quality.py:26 -msgid "" -"The column '{column_name}' was not found in the Threat Data table for the " -"corresponding input LULC scenario." -msgstr "" -"La columna '{column_name}' no se encontró en la tabla de Datos de Amenazas " -"para el escenario LULC de input correspondiente." - -#: src/natcap/invest/habitat_quality.py:29 -#, fuzzy -msgid "" -"A threat raster for threats: {threat_list} was not found or it could not be " -"opened by GDAL." -msgstr "" -"No se halló un ráster de amenazas para las amenazas: {threat_list} o no pudo " -"ser abierta por GDAL." - -#: src/natcap/invest/habitat_quality.py:32 -msgid "Threat paths must be unique. Duplicates: " -msgstr "Las rutas de las amenazas deben ser únicas. Duplicados: " - -#: src/natcap/invest/habitat_quality.py:50 -msgid "" -"Map of LULC at present. All values in this raster must have corresponding " -"entries in the Sensitivity table." -msgstr "" -"Mapa de LULC en la actualidad. Todos los valores de este raster deben tener " -"los inputs correspondientes en la tabla de sensibilidad." - -#: src/natcap/invest/habitat_quality.py:53 -msgid "current land cover" -msgstr "cobertura del suelo actual" - -#: src/natcap/invest/habitat_quality.py:59 -msgid "" -"Map of LULC in a future scenario. All values in this raster must have " -"corresponding entries in the Sensitivity Table. Must use the same " -"classification scheme and codes as in the Current LULC map." -msgstr "" -"Mapa de LULC en un escenario futuro. Todos los valores de este ráster deben " -"tener los inputs correspondientes en la Tabla de Sensibilidad. Debe utilizar " -"el mismo esquema de clasificación y códigos que en el mapa LULC actual." - -#: src/natcap/invest/habitat_quality.py:64 -msgid "future land cover" -msgstr "cobertura futura del suelo" - -#: src/natcap/invest/habitat_quality.py:70 -msgid "" -"Map of LULC in a baseline scenario, when intensive landscape management was " -"relatively rare. All values in this raster must have corresponding entries in " -"the Sensitivity table. Must use the same classification scheme and codes as in " -"the Current LULC map." -msgstr "" -"Mapa de LULC en un escenario de referencia, cuando la gestión intensiva del " -"paisaje era relativamente rara. Todos los valores de este ráster deben tener " -"los inputs correspondientes en la tabla de sensibilidad. Debe utilizar el " -"mismo esquema de clasificación y códigos del mapa LULC actual." - -#: src/natcap/invest/habitat_quality.py:76 -msgid "baseline land cover" -msgstr "cobertura terrestre de línea de base" - -#: src/natcap/invest/habitat_quality.py:83 -msgid "" -"Name of the threat. Each threat name must have a corresponding column in the " -"Sensitivity table." -msgstr "" -"Nombre de la amenaza. Cada nombre de amenaza debe tener una columna " -"correspondiente en la tabla de sensibilidad." - -#: src/natcap/invest/habitat_quality.py:89 -msgid "" -"The maximum distance over which each threat affects habitat quality. The " -"impact of each degradation source will decline to zero at this maximum " -"distance. This value must be greater than or equal to the pixel size of your " -"LULC raster(s)." -msgstr "" -"La distancia máxima a la que cada amenaza afecta a la calidad del hábitat. El " -"impacto de cada fuente de degradación se reducirá a cero en esta distancia " -"máxima. Este valor debe ser mayor o igual que el tamaño del píxel de lo(s) " -"ráster(s) LULC." - -#: src/natcap/invest/habitat_quality.py:98 -msgid "The impact of each threat on habitat quality, relative to other threats." -msgstr "" -"El impacto de cada amenaza en la calidad del hábitat, en relación con otras " -"amenazas." - -#: src/natcap/invest/habitat_quality.py:106 -msgid "Effects of the threat decay linearly with distance from the threat." -msgstr "" -"Los efectos de la amenaza decaen linealmente con la distancia a la amenaza." - -#: src/natcap/invest/habitat_quality.py:110 -msgid "Effects of the threat decay exponentially with distance from the threat." -msgstr "" -"Los efectos de la amenaza decaen exponencialmente con la distancia a esta." - -#: src/natcap/invest/habitat_quality.py:114 -msgid "The type of decay over space for each threat." -msgstr "El tipo de decaimiento a lo largo del espacio para cada amenaza." - -#: src/natcap/invest/habitat_quality.py:119 -msgid "" -"Map of the threat's distribution in the current scenario. Each pixel value is " -"the relative intensity of the threat at that location. " -msgstr "" -"Mapa de la distribución de la amenaza en el escenario actual. El valor de cada " -"píxel es la intensidad relativa de la amenaza en ese lugar. " - -#: src/natcap/invest/habitat_quality.py:128 -msgid "" -"Map of the threat's distribution in the future scenario. Each pixel value is " -"the relative intensity of the threat at that location. Required if Future LULC " -"is provided." -msgstr "" -"Mapa de la distribución de la amenaza en el escenario futuro. El valor de cada " -"píxel es la intensidad relativa de la amenaza en ese lugar. Se requiere si se " -"proporciona el LULC futuro." - -#: src/natcap/invest/habitat_quality.py:138 -msgid "" -"Map of the threat's distribution in the baseline scenario. Each pixel value is " -"the relative intensity of the threat at that location. Required if Baseline " -"LULC is provided." -msgstr "" -"Mapa de la distribución de la amenaza en el escenario base. El valor de cada " -"píxel es la intensidad relativa de la amenaza en ese lugar. Necesario si se " -"proporciona el LULC de referencia." - -#: src/natcap/invest/habitat_quality.py:145 -msgid "" -"Table mapping each threat of interest to its properties and distribution maps. " -"Paths are relative to the threats table path." -msgstr "" -"Tabla que relaciona cada amenaza de interés con sus propiedades y mapas de " -"distribución. Las rutas son relativas a la ruta de la tabla de amenazas." - -#: src/natcap/invest/habitat_quality.py:149 -msgid "threats table" -msgstr "tabla de amenazas" - -#: src/natcap/invest/habitat_quality.py:157 -msgid "" -"The region's relative accessibility to threats, where 0 represents completely " -"inaccessible and 1 represents completely accessible." -msgstr "" -"La accesibilidad relativa de la región a las amenazas, en la que 0 representa " -"que es completamente inaccesible y 1 que es completamente accesible." - -#: src/natcap/invest/habitat_quality.py:165 -msgid "" -"Map of the relative protection that legal, institutional, social, and physical " -"barriers provide against threats. Any cells not covered by a polygon will be " -"set to 1." -msgstr "" -"Mapa de la protección relativa que ofrecen las barreras legales, " -"institucionales, sociales y físicas contra las amenazas. Las celdas que no " -"estén cubiertas por un polígono se establecerán en 1." - -#: src/natcap/invest/habitat_quality.py:169 -msgid "accessibility to threats" -msgstr "accesibilidad a las amenazas" - -#: src/natcap/invest/habitat_quality.py:176 -msgid "LULC codes corresponding to those in the LULC rasters." -msgstr "Códigos LULC correspondientes a los de los rásters LULC." - -#: src/natcap/invest/habitat_quality.py:181 -msgid "" -"Suitability of this LULC class as habitat, where 0 is not suitable and 1 is " -"completely suitable." -msgstr "" -"Aptitud de esta clase de LULC como hábitat, donde 0 es no apto y 1 es " -"completamente apto." - -#: src/natcap/invest/habitat_quality.py:187 -#, fuzzy -msgid "" -"The relative sensitivity of each LULC class to each type of threat, where 1 " -"represents high sensitivity and 0 represents that it is unaffected. There must " -"be one threat column for each threat name in the 'threats' column of the " -"Threats Table." -msgstr "" -"La sensibilidad relativa de cada clase de LULC a cada tipo de amenaza, donde 1 " -"representa una alta sensibilidad y 0 representa que no le afecta. Debe haber " -"una columna de amenazas por cada nombre de amenaza en la columna \"amenazas\" " -"de la Tabla de Amenazas." - -#: src/natcap/invest/habitat_quality.py:195 -msgid "" -"Table mapping each LULC class to data about the species' habitat preference " -"and threat sensitivity in areas with that LULC." -msgstr "" -"Tabla que relaciona cada clase de LULC con los datos sobre la preferencia de " -"hábitat de la especie y la sensibilidad a las amenazas en zonas con ese LULC." - -#: src/natcap/invest/habitat_quality.py:199 -msgid "sensitivity table" -msgstr "tabla de sensibilidad" - -#: src/natcap/invest/habitat_quality.py:205 -msgid "Half-saturation constant used in the degradation equation." -msgstr "Constante de semisaturación utilizada en la ecuación de degradación." - -#: src/natcap/invest/habitat_quality.py:207 -msgid "half-saturation constant" -msgstr "constante de semisaturación" - -#: src/natcap/invest/hra.py:68 -msgid "habitat stressor table" -msgstr "tabla de factores de estrés del hábitat" - -#: src/natcap/invest/hra.py:69 -msgid "A table describing each habitat and stressor." -msgstr "Una tabla que describe cada hábitat y factor de estrés." - -#: src/natcap/invest/hra.py:74 -#, fuzzy -msgid "" -"A unique name for each habitat or stressor. These names must match the habitat " -"and stressor names in the Criteria Scores Table." -msgstr "" -"Un nombre único para cada hábitat o factor de estrés. Estos nombres deben " -"coincidir con los nombres de los hábitats y de los factores de estrés en la " -"tabla de calificaciones de los criterios." - -#: src/natcap/invest/hra.py:83 -msgid "" -"Pixel values are 1, indicating presence of the habitat/stressor, or 0 " -"indicating absence. Any values besides 0 or 1 will be treated as 0." -msgstr "" -"Los valores de los píxeles son 1, que indica la presencia del hábitat/estrés, " -"o 0, que indica la ausencia. Cualquier valor que no sea 0 o 1 se tratará como " -"0." - -#: src/natcap/invest/hra.py:90 -msgid "" -"Map of where the habitat or stressor exists. For rasters, a pixel value of 1 " -"indicates presence of the habitat or stressor. 0 (or any other value) " -"indicates absence of the habitat or stressor. For vectors, a polygon indicates " -"an area where the habitat or stressor is present." -msgstr "" -"Mapa de dónde existe el hábitat o el factor de estrés. En el caso de los " -"rásters, un valor de píxel de 1 indica la presencia del hábitat o del factor " -"de estrés. 0 (o cualquier otro valor) indica la ausencia del hábitat o del " -"factor de estrés. En el caso de los vectores, un polígono indica un área en la " -"que está presente el hábitat o el factor de estrés." - -#: src/natcap/invest/hra.py:101 -msgid "habitat" -msgstr "hábitat" - -#: src/natcap/invest/hra.py:102 -msgid "stressor" -msgstr "factor de estrés" - -#: src/natcap/invest/hra.py:104 -msgid "Whether this row is for a habitat or a stressor." -msgstr "Si esta fila es para un hábitat o un factor de estrés." - -#: src/natcap/invest/hra.py:110 -msgid "" -"The desired buffer distance used to expand a given stressor’s influence or " -"footprint. This should be left blank for habitats, but must be filled in for " -"stressors. Enter 0 if no buffering is desired for a given stressor. The model " -"will round down this buffer distance to the nearest cell unit. e.g., a buffer " -"distance of 600m will buffer a stressor’s footprint by two grid cells if the " -"resolution of analysis is 250m." -msgstr "" -"La distancia de amortiguamiento deseada para ampliar la influencia o la huella " -"de un factor de estrés determinado. Debe dejarse en blanco para los hábitats, " -"pero debe rellenarse para los factores de estrés. Introduzca 0 si no se desea " -"ningún amortiguamiento para un factor determinado. El modelo redondeará hacia " -"abajo esta distancia de amortiguación a la unidad de celda más cercana. Por " -"ejemplo, una distancia de amortiguación de 600m amortiguará la huella de un " -"factor de estrés en dos celdas de la cuadrícula si la resolución del análisis " -"es de 250m." - -#: src/natcap/invest/hra.py:125 -msgid "criteria scores table" -msgstr "tabla de calificaciones de los criterios" - -#: src/natcap/invest/hra.py:126 -msgid "A table of criteria scores for all habitats and stressors." -msgstr "" -"Una tabla de calificaciones de criterios para todos los hábitats y factores de " -"estrés." - -#: src/natcap/invest/hra.py:132 -msgid "resolution of analysis" -msgstr "resolución del análisis" - -#: src/natcap/invest/hra.py:133 -msgid "" -"The resolution at which to run the analysis. The model outputs will have this " -"resolution." -msgstr "" -"La resolución con la que se ejecuta el análisis. Los resultados del modelo " -"tendrán esta resolución." - -#: src/natcap/invest/hra.py:141 -msgid "maximum criteria score" -msgstr "calificación máxima de los criterios" - -#: src/natcap/invest/hra.py:142 -msgid "The highest possible criteria score in the scoring system." -msgstr "" -"La mayor calificación posible de los criterios en el sistema de calificación." - -#: src/natcap/invest/hra.py:149 -msgid "risk equation" -msgstr "ecuación de riesgo" - -#: src/natcap/invest/hra.py:150 -msgid "The equation to use to calculate risk from exposure and consequence." -msgstr "" -"La ecuación que se debe utilizar para calcular el riesgo a partir de la " -"exposición y las consecuencias." - -#: src/natcap/invest/hra.py:155 -msgid "Multiplicative" -msgstr "Multiplicativo" - -#: src/natcap/invest/hra.py:156 -msgid "Euclidean" -msgstr "Euclidiano" - -#: src/natcap/invest/hra.py:160 -msgid "decay equation" -msgstr "ecuación de decaimiento" - -#: src/natcap/invest/hra.py:161 -msgid "The equation to model effects of stressors in buffer areas." -msgstr "" -"La ecuación para modelizar los efectos de los factores de estrés en las zonas " -"de amortiguamiento." - -#: src/natcap/invest/hra.py:166 -msgid "None" -msgstr "Ninguno" - -#: src/natcap/invest/hra.py:167 -msgid "No decay. Stressor has full effect in the buffer area." -msgstr "" -"No hay decaimiento. El factor tiene pleno efecto en la zona de amortiguación." - -#: src/natcap/invest/hra.py:171 -msgid "Linear" -msgstr "Lineal" - -#: src/natcap/invest/hra.py:172 -msgid "" -"Stressor effects in the buffer area decay linearly with distance from the " -"stressor." -msgstr "" -"Los efectos del factor de estres en la zona de amortiguación decaen " -"linealmente con la distancia al factor." - -#: src/natcap/invest/hra.py:176 -msgid "Exponential" -msgstr "Exponencial" - -#: src/natcap/invest/hra.py:177 -msgid "" -"Stressor effects in the buffer area decay exponentially with distance from the " -"stressor." -msgstr "" -"Los efectos del factor en la zona de amortiguación decaen exponencialmente " -"con la distancia al factor." - -#: src/natcap/invest/hra.py:190 -msgid "" -"Uniquely identifies each feature. Required if the vector contains more than " -"one feature." -msgstr "" -"Identifica de forma exclusiva cada característica. Se necesita si el vector " -"contiene más de una característica." - -#: src/natcap/invest/hra.py:195 -msgid "" -"A GDAL-supported vector file containing features representing one or more " -"planning regions or subregions." -msgstr "" -"Un archivo vectorial compatible con GDAL que contiene características que " -"representan una o más regiones o subregiones de planificación." - -#: src/natcap/invest/hra.py:200 -msgid "Number of Overlapping Stressors" -msgstr "Número de factores de estrés superpuestos" - -#: src/natcap/invest/hra.py:203 -msgid "" -"The number of overlapping stressors to consider as 'maximum' when " -"reclassifying risk scores into high/medium/low. Affects the breaks between " -"risk classifications." -msgstr "" -"El número de factores de estrés superpuestos a considerar como \"máximo\" al " -"reclasificar las calificaciones de riesgo en alto/medio/bajo. Afecta a las " -"rupturas entre las clasificaciones de riesgo." - -#: src/natcap/invest/hra.py:212 -msgid "Generate GeoJSONs" -msgstr "Generar GeoJSONs" - -#: src/natcap/invest/hra.py:213 -msgid "Generate GeoJSON outputs for web visualization." -msgstr "Generar resultados GeoJSON para la visualización web." - -#: src/natcap/invest/model_metadata.py:18 -msgid "Annual Water Yield" -msgstr "Rendimiento anual de agua" - -#: src/natcap/invest/model_metadata.py:24 -msgid "Carbon Storage and Sequestration" -msgstr "Almacenamiento y secuestración de carbono" - -#: src/natcap/invest/model_metadata.py:30 -msgid "Coastal Blue Carbon" -msgstr "Carbono azul costero" - -#: src/natcap/invest/model_metadata.py:36 -msgid "Coastal Blue Carbon Preprocessor" -msgstr "Preprocesador de Carbono azul costero" - -#: src/natcap/invest/model_metadata.py:42 -msgid "Coastal Vulnerability" -msgstr "Vulnerabilidad costera" - -#: src/natcap/invest/model_metadata.py:48 -msgid "Crop Production: Percentile" -msgstr "Producción de cultivos: Percentil" - -#: src/natcap/invest/model_metadata.py:54 -msgid "Crop Production: Regression" -msgstr "Producción de cultivos: Regresión" - -#: src/natcap/invest/model_metadata.py:60 -msgid "DelineateIt" -msgstr "DelineateIt" - -#: src/natcap/invest/model_metadata.py:66 -msgid "Forest Carbon Edge Effect" -msgstr "Efecto de borde del carbono forestal" - -#: src/natcap/invest/model_metadata.py:72 -msgid "GLOBIO" -msgstr "GLOBIO" - -#: src/natcap/invest/model_metadata.py:78 -msgid "Habitat Quality" -msgstr "Calidad del hábitat" - -#: src/natcap/invest/model_metadata.py:84 -msgid "Habitat Risk Assessment" -msgstr "Evaluación del riesgo del hábitat" - -#: src/natcap/invest/model_metadata.py:90 -msgid "Nutrient Delivery Ratio" -msgstr "Proporción de suministro de nutrientes" - -#: src/natcap/invest/model_metadata.py:96 -msgid "Crop Pollination" -msgstr "Polinización de cultivos" - -#: src/natcap/invest/model_metadata.py:102 -msgid "Visitation: Recreation and Tourism" -msgstr "Visitación: Ocio y Turismo" - -#: src/natcap/invest/model_metadata.py:108 -msgid "RouteDEM" -msgstr "RouteDEM" - -#: src/natcap/invest/model_metadata.py:114 -msgid "Scenario Generator: Proximity Based" -msgstr "Generador de escenarios: Basado en la proximidad" - -#: src/natcap/invest/model_metadata.py:120 -msgid "Scenic Quality" -msgstr "Calidad paisajística" - -#: src/natcap/invest/model_metadata.py:126 -msgid "Sediment Delivery Ratio" -msgstr "Tasa de suministro de sedimentos" - -#: src/natcap/invest/model_metadata.py:132 -msgid "Seasonal Water Yield" -msgstr "Rendimiento hídrico estacional" - -#: src/natcap/invest/model_metadata.py:138 -msgid "Urban Stormwater Retention" -msgstr "Retención de aguas pluviales urbanas" - -#: src/natcap/invest/model_metadata.py:144 -msgid "Wave Energy Production" -msgstr "Producción de energía de las olas" - -#: src/natcap/invest/model_metadata.py:150 -msgid "Wind Energy Production" -msgstr "Producción de energía eólica" - -#: src/natcap/invest/model_metadata.py:156 -msgid "Urban Flood Risk Mitigation" -msgstr "Mitigación del riesgo de inundaciones urbanas" - -#: src/natcap/invest/model_metadata.py:162 -msgid "Urban Cooling" -msgstr "Enfriamiento urbano" - -#: src/natcap/invest/pollination.py:37 -msgid "" -"Map of LULC codes. All values in this raster must have corresponding entries " -"in the Biophysical Table." -msgstr "" -"Mapa de códigos LULC. Todos los valores de este ráster deben tener los inputs " -"correspondientes en la Tabla Biofísica." - -#: src/natcap/invest/pollination.py:46 -msgid "" -"Unique name or identifier for each pollinator species or guild of interest." -msgstr "" -"Nombre o identificador único para cada especie o gremio de polinizadores de " -"interés." - -#: src/natcap/invest/pollination.py:52 -msgid "" -"Utilization of the substrate by this species, where 1 indicates the nesting " -"substrate is fully utilized and 0 indicates it is not utilized at all. Replace " -"[SUBSTRATE] with substrate names matching those in the Biophysical Table, so " -"that there is a column for each substrate." -msgstr "" -"Utilización del sustrato por parte de esta especie, donde 1 indica que el " -"sustrato de anidación se utiliza completamente y 0 indica que no se utiliza en " -"absoluto. Reemplace [SUSTRATO] con nombres de sustratos que coincidan con los " -"de la Tabla Biofísica, de modo que haya una columna para cada sustrato." - -#: src/natcap/invest/pollination.py:62 -msgid "" -"Pollinator activity for this species/guild in each season. 1 indicates maximum " -"activity for the species/guild, and 0 indicates no activity. Replace [SEASON] " -"with season names matching those in the biophysical table, so that there is a " -"column for each season." -msgstr "" -"Actividad de los polinizadores para esta especie o gremio en cada estación. el " -"1 indica la máxima actividad de la especie o gremio, y el 0 indica que no hay " -"actividad. Sustituya [ESTACIÓN] por los nombres de las estaciones que " -"coincidan con los de la tabla biofísica, de modo que haya una columna para " -"cada estación." - -#: src/natcap/invest/pollination.py:73 -msgid "Average distance that this species or guild travels to forage on flowers." -msgstr "" -"Distancia media que recorre esta especie o gremio para alimentarse de flores." - -#: src/natcap/invest/pollination.py:79 -msgid "" -"The proportion of total pollinator abundance that consists of this species/" -"guild." -msgstr "" -"La proporción de la abundancia total de polinizadores que consiste en esta " -"especie/gremio." - -#: src/natcap/invest/pollination.py:84 -msgid "" -"A table mapping each pollinator species or guild of interest to its " -"pollination-related parameters." -msgstr "" -"Una tabla que mapea cada especie o gremio de polinizadores de interés con sus " -"parámetros relacionados con la polinización." - -#: src/natcap/invest/pollination.py:87 -msgid "Guild Table" -msgstr "Tabla de gremios" - -#: src/natcap/invest/pollination.py:94 -msgid "LULC code representing this class in the LULC raster." -msgstr "Código LULC que representa esta clase en el ráster LULC." - -#: src/natcap/invest/pollination.py:100 -msgid "" -"Index of availability of the given substrate in this LULC class. Replace " -"[SUBSTRATE] with substrate names matching those in the Guild Table, so that " -"there is a column for each substrate." -msgstr "" -"Índice de disponibilidad del sustrato dado en esta clase LULC. Sustituir " -"[SUSTRATO] por los nombres de los sustratos que coincidan con los de la tabla " -"de gremios, de modo que haya una columna para cada sustrato." - -#: src/natcap/invest/pollination.py:107 -msgid "" -"Abundance of flowers during the given season in this LULC class. This is the " -"proportion of land area covered by flowers, multiplied by the proportion of " -"the season for which there is that coverage. Replace [SEASON] with season " -"names matching those in the Guild Table, so that there is a column for each " -"season." -msgstr "" -"Abundancia de flores durante la estación dada en esta clase de LULC. Se trata " -"de la proporción de superficie cubierta por flores, multiplicada por la " -"proporción de la estación para la que existe esa cobertura. Sustituya " -"[ESTACIÓN] por los nombres de las estaciones que coincidan con los de la tabla " -"de gremios, de modo que haya una columna para cada estación." - -#: src/natcap/invest/pollination.py:116 -msgid "" -"A table mapping each LULC class to nesting availability and floral abundance " -"data for each substrate and season in that LULC class. All values in the LULC " -"raster must have corresponding entries in this table." -msgstr "" -"Una tabla que relacione cada clase de LULC con los datos de disponibilidad de " -"nidos y abundancia de flores para cada sustrato y estación en esa clase de " -"LULC. Todos los valores de la trama LULC deben tener sus correspondientes " -"inputs en esta tabla." - -#: src/natcap/invest/pollination.py:128 -msgid "" -"Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', etc." -msgstr "" - -#: src/natcap/invest/pollination.py:133 -msgid "" -"The half saturation coefficient for the crop grown in this area. This is the " -"wild pollinator abundance (i.e. the proportion of all pollinators that are " -"wild) needed to reach half of the total potential pollinator-dependent yield." -msgstr "" -"El coeficiente de media saturación para el cultivo que se produce en esta " -"zona. Se trata de la abundancia de polinizadores silvestres (es decir, la " -"proporción de todos los polinizadores que son silvestres) necesaria para " -"alcanzar la mitad del rendimiento total potencial dependiente de los " -"polinizadores." - -#: src/natcap/invest/pollination.py:141 -#, fuzzy -msgid "" -"The season in which the crop is pollinated. Season names must match those in " -"the Guild Table and Biophysical Table." -msgstr "" -"La estación en la que se poliniza el cultivo. Los nombres de las estaciones " -"deben coincidir con los de la Tabla de gremios y la Tabla biofísica." - -#: src/natcap/invest/pollination.py:147 -msgid "" -"The floral resources available at this farm for the given season. Replace " -"[SEASON] with season names matching those in the Guild Table and Biophysical " -"Table, so that there is one field for each season." -msgstr "" -"Los recursos florales disponibles en esta granja para la temporada dada. " -"Sustituya [ESTACIÓN] por los nombres de las estaciones que coincidan con los " -"de la Tabla de Gremios y la Tabla Biofísica, de modo que haya un campo para " -"cada estación." - -#: src/natcap/invest/pollination.py:155 -msgid "" -"The nesting suitability for the given substrate at this farm. given substrate. " -"Replace [SUBSTRATE] with substrate names matching those in the Guild Table and " -"Biophysical Table, so that there is one field for each substrate." -msgstr "" -"La idoneidad de anidación para el sustrato dado en esta granja. sustrato dado. " -"Sustituir [SUSTRATO] por los nombres de los sustratos que coincidan con los de " -"la tabla de gremios y la tabla biofísica, de modo que haya un campo para cada " -"sustrato." - -#: src/natcap/invest/pollination.py:163 -msgid "The proportion of crop dependent on pollinators." -msgstr "La proporción de cultivos que dependen de los polinizadores." - -#: src/natcap/invest/pollination.py:168 -msgid "" -"The proportion of pollination required on the farm that is provided by managed " -"pollinators." -msgstr "" -"La proporción de la polinización necesaria en la finca que es proporcionada " -"por los polinizadores gestionados." - -#: src/natcap/invest/pollination.py:174 -msgid "" -"Map of farm sites to be analyzed, with pollination data specific to each farm." -msgstr "" -"Mapa de lis sitios de las fincas que se van a analizar, con los datos de " -"polinización específicos de cada finca." - -#: src/natcap/invest/pollination.py:177 -msgid "farms map" -msgstr "mapa de fincas" - -#: src/natcap/invest/routedem.py:20 -msgid "Must be between 1 and {maximum}" -msgstr "Debe estar entre 1 y {maximum}" - -#: src/natcap/invest/routedem.py:36 -msgid "Index of the raster band to use, for multi-band rasters." -msgstr "" -"Índice de la banda del ráster que se va a utilizar, para los rásters " -"multibanda." - -#: src/natcap/invest/routedem.py:38 -msgid "band index" -msgstr "índice de bandas" - -#: src/natcap/invest/routedem.py:45 -msgid "" -"All water on a pixel flows into the most downhill of its 8 surrounding pixels" -msgstr "" -"Toda el agua de un píxel fluye hacia el más bajo de sus 8 píxeles circundantes" - -#: src/natcap/invest/routedem.py:50 -msgid "" -"Flow off a pixel is modeled fractionally so that water is split among multiple " -"downslope pixels" -msgstr "" -"El flujo de un píxel se modeliza de forma fraccionada para que el agua se " -"reparta entre varios píxeles pendiente abajo" - -#: src/natcap/invest/routedem.py:54 -msgid "The routing algorithm to use." -msgstr "El algoritmo de enrutamiento a utilizar." - -#: src/natcap/invest/routedem.py:55 -msgid "routing algorithm" -msgstr "algoritmo de enrutamiento" - -#: src/natcap/invest/routedem.py:60 -msgid "Calculate flow direction from the provided DEM." -msgstr "Calcule la dirección del flujo a partir del MDE proporcionado." - -#: src/natcap/invest/routedem.py:61 -msgid "calculate flow direction" -msgstr "cálcular la dirección del flujo" - -#: src/natcap/invest/routedem.py:66 -msgid "Calculate flow accumulation from the flow direction output." -msgstr "" -"Calcular la acumulación de flujo a partir de la salida de la dirección del " -"flujo." - -#: src/natcap/invest/routedem.py:68 -msgid "calculate flow accumulation" -msgstr "cálcular la acumulación de flujo" - -#: src/natcap/invest/routedem.py:73 -msgid "Calculate streams from the flow accumulation output. " -msgstr "Calcular los flujos a partir de la salida de la acumulación de flujos. " - -#: src/natcap/invest/routedem.py:75 -msgid "calculate streams" -msgstr "calcular ls corrientes" - -#: src/natcap/invest/routedem.py:82 -msgid "Required if Calculate Streams is selected." -msgstr "Necesario si se selecciona la opción de calcular corrientes." - -#: src/natcap/invest/routedem.py:87 -msgid "" -"Calculate flow distance from each pixel to a stream as defined in the " -"Calculate Streams output." -msgstr "" -"Calcule la distancia del flujo de cada píxel a una corriente como se define en " -"el resultado de Calcular corrientes." - -#: src/natcap/invest/routedem.py:90 -msgid "calculate distance to stream" -msgstr "calcular la distancia a la corriente" - -#: src/natcap/invest/routedem.py:95 -msgid "Calculate percent slope from the provided DEM." -msgstr "Calcule el porcentaje de pendiente a partir del MDE proporcionado." - -#: src/natcap/invest/routedem.py:96 -msgid "calculate slope" -msgstr "calcular la pendiente" - -#: src/natcap/invest/scenario_gen_proximity.py:29 -#, fuzzy -msgid "" -"One or more of \"convert_nearest_to_edge\" or \"convert_farthest_from_edge\" " -"must be selected" -msgstr "" -"Debe seleccionarse una o varias de las opciones " -"\"convertir_más_cercano_al_borde\" o \"convertir_más_alejado_del_borde\"" - -#: src/natcap/invest/scenario_gen_proximity.py:44 -msgid "Base map from which to generate scenarios." -msgstr "Mapa base a partir del cual se generan los escenarios." - -#: src/natcap/invest/scenario_gen_proximity.py:45 -msgid "base LULC map" -msgstr "mapa LULC base" - -#: src/natcap/invest/scenario_gen_proximity.py:49 -msgid "The LULC code to which habitat will be converted." -msgstr "El código LULC al que se convertirá el hábitat." - -#: src/natcap/invest/scenario_gen_proximity.py:50 -msgid "replacement landcover code" -msgstr "código de sustitución de la cubierta vegetal" - -#: src/natcap/invest/scenario_gen_proximity.py:56 -msgid "Maximum area to be converted to agriculture." -msgstr "Superficie máxima a convertir en agricultura." - -#: src/natcap/invest/scenario_gen_proximity.py:57 -msgid "maximum area to convert" -msgstr "superficie máxima a convertir" - -#: src/natcap/invest/scenario_gen_proximity.py:62 -#, fuzzy -msgid "" -"A space-separated list of LULC codes that are used to determine the proximity " -"when referring to 'towards' or 'away' from the base landcover codes" -msgstr "" -"Una lista separada por espacios de los códigos LULC que se utilizan para " -"determinar la proximidad cuando se refiere a \"hacia\" o \"lejos\" de los " -"códigos de la cobertura del suelo base" - -#: src/natcap/invest/scenario_gen_proximity.py:66 -msgid "focal landcover codes" -msgstr "códigos focales de la cubierta vegetal" - -#: src/natcap/invest/scenario_gen_proximity.py:71 -msgid "" -"A space-separated list of LULC codes that can be converted to be converted to " -"agriculture." -msgstr "" -"Una lista separada por espacios de los códigos LULC que pueden ser convertidos " -"a la agricultura." - -#: src/natcap/invest/scenario_gen_proximity.py:74 -msgid "convertible landcover codes" -msgstr "códigos de la cubierta terrestre convertibles" - -#: src/natcap/invest/scenario_gen_proximity.py:80 -msgid "" -"The number of steps that the simulation should take to fragment the habitat of " -"interest in the fragmentation scenario. This parameter is used to divide the " -"conversion simulation into equal subareas of the requested max area. During " -"each sub-step the distance transform is recalculated from the base landcover " -"codes. This can affect the final result if the base types are also " -"convertible types." -msgstr "" -"El número de pasos que debe dar la simulación para fragmentar el hábitat de " -"interés en el escenario de fragmentación. Este parámetro se utiliza para " -"dividir la simulación de conversión en subáreas iguales del área máxima " -"solicitada. Durante cada subpaso, la transformación de la distancia se " -"recalcula a partir de los códigos de la cobertura del suelo base. Esto puede " -"afectar el resultado final si los tipos base son también tipos convertibles." - -#: src/natcap/invest/scenario_gen_proximity.py:88 -msgid "number of conversion steps" -msgstr "número de pasos de conversión" - -#: src/natcap/invest/scenario_gen_proximity.py:93 -msgid "" -"Area over which to run the conversion. Provide this input if change is only " -"desired in a subregion of the Base LULC map." -msgstr "" -"Área sobre la que se va a realizar la conversión. Proporcione este input si " -"solo desea un cambio en una subregión del mapa LULC base." - -#: src/natcap/invest/scenario_gen_proximity.py:99 -msgid "" -"Convert the 'convertible' landcover codes starting at the furthest pixel from " -"the 'focal' land cover areas and working inwards." -msgstr "" -"Convierta los códigos de cobertura del suelo \"convertibles\" empezando por el " -"píxel más alejado de las zonas de cobertura del suelo \"focales\" y trabajando " -"hacia el interior." - -#: src/natcap/invest/scenario_gen_proximity.py:103 -msgid "convert farthest from edge" -msgstr "convertir más lejos del borde" - -#: src/natcap/invest/scenario_gen_proximity.py:107 -msgid "" -"Convert the 'convertible' landcover codes starting at the nearest pixels to " -"the 'focal' land cover areas and working outwards." -msgstr "" -"Convierta los códigos de la cubierta terrestre \"convertible\" empezando por " -"los píxeles más cercanos a las zonas de la cubierta terrestre \"focal\" y " -"trabajando hacia fuera." - -#: src/natcap/invest/scenario_gen_proximity.py:111 -msgid "convert nearest to edge" -msgstr "convertir lo más cercano al borde" - -#: src/natcap/invest/spec_utils.py:18 -msgid "workspace" -msgstr "espacio de trabajo" - -#: src/natcap/invest/spec_utils.py:19 -msgid "" -"The folder where all the model's output files will be written. If this folder " -"does not exist, it will be created. If data already exists in the folder, it " -"will be overwritten." -msgstr "" -"La carpeta donde se escribirán todos los archivos resultantes del modelo. Si " -"esta carpeta no existe, se creará. Si los datos ya existen en la carpeta, se " -"sobrescribirán." - -#: src/natcap/invest/spec_utils.py:30 -msgid "file suffix" -msgstr "sufijo del archivo" - -#: src/natcap/invest/spec_utils.py:31 -msgid "" -"Suffix that will be appended to all output file names. Useful to differentiate " -"between model runs." -msgstr "" -"Sufijo que se añadirá a todos los nombres de archivos resultantes. Es útil " -"para diferenciar entre las ejecuciones del modelo." - -#: src/natcap/invest/spec_utils.py:40 -#, fuzzy -msgid "taskgraph n_workers parameter" -msgstr "Parámetro n_workers del gráfico de tareas" - -#: src/natcap/invest/spec_utils.py:41 -#, fuzzy -msgid "" -"The n_workers parameter to provide to taskgraph. -1 will cause all jobs to run " -"synchronously. 0 will run all jobs in the same process, but scheduling will " -"take place asynchronously. Any other positive integer will cause that many " -"processes to be spawned to execute tasks." -msgstr "" -"El parámetro n_workers a proporcionar a taskgraph. -1 hará que todos los " -"trabajos se ejecuten de forma sincrónica. 0 hará que todos los trabajos se " -"ejecuten en el mismo proceso, pero la programación tendrá lugar de forma " -"asíncrona. Cualquier otro número entero positivo hará que se generen ese " -"número de procesos para ejecutar las tareas." - -#: src/natcap/invest/spec_utils.py:66 -msgid "area of interest" -msgstr "área de interés" - -#: src/natcap/invest/spec_utils.py:67 -msgid "A map of areas over which to aggregate and summarize the final results." -msgstr "Un mapa de zonas sobre el que agregar y resumir los resultados finales." - -#: src/natcap/invest/spec_utils.py:74 -msgid "Map of land use/land cover codes." -msgstr "Mapa de códigos de uso y cobertura del suelo." - -#: src/natcap/invest/spec_utils.py:75 -msgid "land use/land cover" -msgstr "uso del suelo/cobertura del suelo" - -#: src/natcap/invest/spec_utils.py:85 -msgid "Map of elevation above sea level." -msgstr "Mapa de elevación sobre el nivel del mar." - -#: src/natcap/invest/spec_utils.py:86 -msgid "digital elevation model" -msgstr "modelo digital de elevación" - -#: src/natcap/invest/spec_utils.py:96 -msgid "Map of average annual precipitation." -msgstr "Mapa de la precipitación media anual." - -#: src/natcap/invest/spec_utils.py:97 -msgid "precipitation" -msgstr "precipitación" - -#: src/natcap/invest/spec_utils.py:100 -msgid "evapotranspiration" -msgstr "evapotranspiración" - -#: src/natcap/invest/spec_utils.py:108 -msgid "Map of evapotranspiration values." -msgstr "Mapa de valores de evapotranspiración." - -#: src/natcap/invest/spec_utils.py:113 -msgid "" -"Map of soil hydrologic groups. Pixels may have values 1, 2, 3, or 4, " -"corresponding to soil hydrologic groups A, B, C, or D, respectively." -msgstr "" -"Mapa de los grupos hidrológicos del suelo. Los píxeles pueden tener los " -"valores 1, 2, 3 o 4, correspondientes a los grupos hidrológicos de suelo A, B, " -"C o D, respectivamente." - -#: src/natcap/invest/spec_utils.py:116 -msgid "soil hydrologic group" -msgstr "grupo hidrológico del suelo" - -#: src/natcap/invest/spec_utils.py:122 -msgid "" -"The number of upslope pixels that must flow into a pixel before it is " -"classified as a stream." -msgstr "" -"El número de píxeles pendiente arriba que deben fluir en un píxel antes de que " -"se clasifique como una corriente." - -#: src/natcap/invest/spec_utils.py:125 -msgid "threshold flow accumulation" -msgstr "umbral de acumulación de flujo" - -#: src/natcap/invest/spec_utils.py:230 -#, fuzzy -msgid "POINT" -msgstr "POINT" - -#: src/natcap/invest/spec_utils.py:231 -#, fuzzy -msgid "MULTIPOINT" -msgstr "MULTIPOINT" - -#: src/natcap/invest/spec_utils.py:232 -#, fuzzy -msgid "LINESTRING" -msgstr "LINESTRING" - -#: src/natcap/invest/spec_utils.py:233 -#, fuzzy -msgid "MULTILINESTRING" -msgstr "MULTILINESTRING" - -#: src/natcap/invest/spec_utils.py:234 -#, fuzzy -msgid "POLYGON" -msgstr "POLYGON" - -#: src/natcap/invest/spec_utils.py:235 -#, fuzzy -msgid "MULTIPOLYGON" -msgstr "MULTIPOLYGON" - -#: src/natcap/invest/spec_utils.py:251 -msgid "required" -msgstr "requerido" - -#: src/natcap/invest/spec_utils.py:253 -msgid "optional" -msgstr "opcional" - -#: src/natcap/invest/spec_utils.py:256 -msgid "conditionally required" -msgstr "condicionalmente requerido" - -#: src/natcap/invest/spec_utils.py:286 -msgid "read" -msgstr "leer" - -#: src/natcap/invest/spec_utils.py:288 -msgid "write" -msgstr "escribir" - -#: src/natcap/invest/spec_utils.py:290 -msgid "execute" -msgstr "ejecutar" - -#: src/natcap/invest/spec_utils.py:363 -msgid "true/false" -msgstr "verdadero/falso" - -#: src/natcap/invest/spec_utils.py:364 -msgid "CSV" -msgstr "CSV" - -#: src/natcap/invest/spec_utils.py:365 -msgid "directory" -msgstr "directorio" - -#: src/natcap/invest/spec_utils.py:366 -msgid "file" -msgstr "archivo" - -#: src/natcap/invest/spec_utils.py:367 -msgid "text" -msgstr "texto" - -#: src/natcap/invest/spec_utils.py:368 -msgid "integer" -msgstr "entero" - -#: src/natcap/invest/spec_utils.py:369 -msgid "number" -msgstr "número" - -#: src/natcap/invest/spec_utils.py:370 -msgid "option" -msgstr "opción" - -#: src/natcap/invest/spec_utils.py:371 -msgid "percent" -msgstr "porcentaje" - -#: src/natcap/invest/spec_utils.py:372 -msgid "raster" -msgstr "ráster" - -#: src/natcap/invest/spec_utils.py:373 -msgid "ratio" -msgstr "proporción" - -#: src/natcap/invest/spec_utils.py:374 -msgid "vector" -msgstr "vector" - -#: src/natcap/invest/spec_utils.py:471 src/natcap/invest/spec_utils.py:475 -msgid "Options:" -msgstr "Opciones:" - -#: src/natcap/invest/spec_utils.py:479 -msgid " Please see the sample data table for details on the format." -msgstr " Consulte la tabla de datos de muestra para conocer el formato." - -#: src/natcap/invest/stormwater.py:56 -msgid "" -"Event mean concentration of the pollutant in stormwater. You may include any " -"number of these columns for different pollutants, or none at all." -msgstr "" -"Concentración media del contaminante del evento en las aguas pluviales. Puede " -"incluir cualquier número de estas columnas para diferentes contaminantes, o " -"ninguna." - -#: src/natcap/invest/stormwater.py:65 -msgid "Stormwater runoff coefficient for soil group" -msgstr "Coeficiente de escorrentía de aguas pluviales para el grupo de suelos" - -#: src/natcap/invest/stormwater.py:74 -msgid "Stormwater percolation coefficient for soil group" -msgstr "" -"Coeficiente de percolación de las aguas pluviales para el grupo de suelos" - -#: src/natcap/invest/stormwater.py:84 -#, fuzzy -msgid "" -"Enter 1 if the LULC class is a connected impervious surface, 0 if not. This " -"column is only used if the 'adjust retention ratios' option is selected. If " -"'adjust retention ratios' is selected and this column exists, the adjustment " -"algorithm takes into account the LULC as well as road centerlines. If this " -"column does not exist, only the road centerlines are used." -msgstr "" -"Introduzca 1 si la clase LULC es una superficie impermeable conectada, 0 si no " -"lo es. Esta columna solo se utiliza si se selecciona la opción \"ajustar los " -"coeficientes de retención\". Si se selecciona la opción \"ajustar relaciones " -"de retención\" y esta columna existe, el algoritmo de ajuste tiene en cuenta " -"la LULC y las líneas centrales de las carreteras. Si esta columna no existe, " -"solo se utilizan las líneas centrales de las carreteras." - -#: src/natcap/invest/stormwater.py:95 -msgid "" -"Table mapping each LULC code found in the LULC raster to biophysical data " -"about that LULC class. If you provide the percolation coefficient column " -"(PE_[X]) for any soil group, you must provide it for all four soil groups." -msgstr "" -"Tabla que asigna cada código LULC encontrado en el ráster LULC a los datos " -"biofísicos sobre esa clase LULC. Si proporciona la columna del coeficiente de " -"percolación (PE_[X]) para cualquier grupo de suelos, debe proporcionarla para " -"los cuatro grupos de suelos." - -#: src/natcap/invest/stormwater.py:100 -msgid "Biophysical table" -msgstr "Tabla biofísica" - -#: src/natcap/invest/stormwater.py:104 -#, fuzzy -msgid "" -"If true, adjust retention ratios. The adjustment algorithm accounts for " -"drainage effects of nearby impervious surfaces which are directly connected to " -"artifical urban drainage channels (typically roads, parking lots, etc.) " -"Connected impervious surfaces are indicated by the is_connected columnin the " -"biophysical table and/or the road centerlines vector." -msgstr "" -"Si es cierto, ajusta los coeficientes de retención. El algoritmo de ajuste " -"tiene en cuenta los efectos del drenaje de las superficies impermeables " -"cercanas que están directamente conectadas a los canales de drenaje urbano " -"artificiales (normalmente carreteras, estacionamientos, etc.). Las superficies " -"impermeables conectadas se indican mediante la columna is_connected en la " -"tabla biofísica y/o el vector de líneas centrales de carreteras." - -#: src/natcap/invest/stormwater.py:111 -msgid "Adjust retention ratios" -msgstr "Ajustar las tasas de retención" - -#: src/natcap/invest/stormwater.py:117 -msgid "" -"Radius around each pixel to adjust retention ratios. Measured in raster " -"coordinate system units. For the adjustment algorithm, a pixel is 'near' a " -"connected impervious surface if its centerpoint is within this radius of " -"connected-impervious LULC and/or a road centerline." -msgstr "" -"Radio alrededor de cada píxel para ajustar las relaciones de retención. Medido " -"en unidades del sistema de coordenadas raster. Para el algoritmo de ajuste, un " -"píxel está \"cerca\" de una superficie impermeable conectada si su punto " -"central está dentro de este radio de LULC impermeable conectada y/o una línea " -"central de carretera." - -#: src/natcap/invest/stormwater.py:123 -msgid "Retention radius" -msgstr "Radio de retención" - -#: src/natcap/invest/stormwater.py:130 -msgid "Map of road centerlines" -msgstr "Mapa de líneas centrales de carreteras" - -#: src/natcap/invest/stormwater.py:131 -msgid "Road centerlines" -msgstr "Líneas centrales de la carretera" - -#: src/natcap/invest/stormwater.py:136 -msgid "" -"Areas over which to aggregate results (typically watersheds or sewersheds). " -"The aggregated data are: average retention ratio and total retention volume; " -"average percolation ratio and total percolation volume if percolation data was " -"provided; total retention value if replacement cost was provided; and total " -"avoided pollutant load for each pollutant provided." -msgstr "" -"Zonas sobre las que se van a agregar los resultados (normalmente cuencas " -"hidrográficas o de alcantarillado). Los datos agregados son: ratio de " -"retención media y volumen de retención total; ratio de percolación media y " -"volumen de percolación total si se facilitan datos de percolación; valor de " -"retención total si se facilita el costo de reposición; y carga contaminante " -"total evitada para cada contaminante facilitado." - -#: src/natcap/invest/stormwater.py:149 -msgid "Replacement cost of stormwater retention devices" -msgstr "Costo de sustitución de los dispositivos de retención de aguas pluviales" - -#: src/natcap/invest/stormwater.py:150 -msgid "Replacement cost" -msgstr "Costo de sustitución" - -#: src/natcap/invest/urban_cooling_model.py:48 -msgid "" -"Map of LULC for the area of interest. All values in this raster must have " -"corresponding entries in the Biophysical Table." -msgstr "" -"Mapa de LULC para el área de interés. Todos los valores de este ráster deben " -"tener los inputs correspondientes en la Tabla Biofísica." - -#: src/natcap/invest/urban_cooling_model.py:61 -msgid "LULC code corresponding to those in the LULC map." -msgstr "Código LULC correspondiente a los del mapa LULC." - -#: src/natcap/invest/urban_cooling_model.py:69 -msgid "" -"Enter 1 to indicate that the LULC is considered a green area. Enter 0 to " -"indicate that the LULC is not considered a green area." -msgstr "" -"Introduzca 1 para indicar que el LULC se considera una zona verde. Introduzca " -"0 para indicar que el LULC no se considera una zona verde." - -#: src/natcap/invest/urban_cooling_model.py:76 -msgid "" -"The proportion of area in this LULC class that is covered by tree canopy at " -"least 2 meters high. Required if the 'factors' option is selected for the " -"Cooling Capacity Calculation Method." -msgstr "" -"Proporción de la superficie de esta clase de LULC que está cubierta por un " -"dosel de árboles de al menos 2 metros de altura. Necesario si se selecciona la " -"opción \"factores\" para el método de cálculo de la capacidad de enfriamiento." - -#: src/natcap/invest/urban_cooling_model.py:84 -msgid "" -"The proportion of solar radiation that is directly reflected by this LULC " -"class. Required if the 'factors' option is selected for the Cooling Capacity " -"Calculation Method." -msgstr "" -"Proporción de la radiación solar que refleja directamente esta clase de LULC. " -"Necesaria si se selecciona la opción \"factores\" para el método de cálculo de " -"la capacidad de enfriamiento." - -#: src/natcap/invest/urban_cooling_model.py:92 -msgid "" -"The ratio of building floor area to footprint area, with all values in this " -"column normalized between 0 and 1. Required if the 'intensity' option is " -"selected for the Cooling Capacity Calculation Method." -msgstr "" -"La relación entre la superficie de piso de la construcción y la superficie de " -"la huella, con todos los valores de esta columna normalizados entre 0 y 1. " -"Necesaria si se selecciona la opción \"intensidad\" para el método de cálculo " -"de la capacidad de enfriamiento." - -#: src/natcap/invest/urban_cooling_model.py:99 -msgid "" -"A table mapping each LULC code to biophysical data for that LULC class. All " -"values in the LULC raster must have corresponding entries in this table." -msgstr "" -"Una tabla que asigna cada código LULC a los datos biofísicos de esa clase " -"LULC. Todos los valores del ráster LULC deben tener los inputs " -"correspondientes en esta tabla." - -#: src/natcap/invest/urban_cooling_model.py:108 -msgid "maximum cooling distance" -msgstr "distancia máxima de enfriamiento" - -#: src/natcap/invest/urban_cooling_model.py:109 -msgid "" -"Distance over which green areas larger than 2 hectares have a cooling effect." -msgstr "" -"Distancia en la que las zonas verdes de más de 2 hectáreas tienen un efecto " -"refrigerante." - -#: src/natcap/invest/urban_cooling_model.py:117 -msgid "air blending distance" -msgstr "distancia de mezcla de aire" - -#: src/natcap/invest/urban_cooling_model.py:118 -msgid "Radius over which to average air temperatures to account for air mixing." -msgstr "" -"Radio sobre el que se promedian las temperaturas del aire para considerar la " -"mezcla del aire." - -#: src/natcap/invest/urban_cooling_model.py:123 -msgid "reference air temperature" -msgstr "temperatura del aire de referencia" - -#: src/natcap/invest/urban_cooling_model.py:126 -msgid "" -"Air temperature in a rural reference area where the urban heat island effect " -"is not observed." -msgstr "" -"Temperatura del aire en una zona rural de referencia en la que no se observa " -"el efecto de isla de calor urbana." - -#: src/natcap/invest/urban_cooling_model.py:131 -msgid "UHI effect" -msgstr "Efecto isla de calor urbana" - -#: src/natcap/invest/urban_cooling_model.py:134 -msgid "" -"The magnitude of the urban heat island effect, i.e., the difference between " -"the rural reference temperature and the maximum temperature observed in the " -"city." -msgstr "" -"La magnitud del efecto isla de calor urbana, es decir, la diferencia entre la " -"temperatura de referencia rural y la temperatura máxima observada en la ciudad." - -#: src/natcap/invest/urban_cooling_model.py:140 -msgid "run energy savings valuation" -msgstr "ejecutar la valoración del ahorro de energía" - -#: src/natcap/invest/urban_cooling_model.py:142 -msgid "Run the energy savings valuation model." -msgstr "Ejecutar el modelo de valoración del ahorro energético." - -#: src/natcap/invest/urban_cooling_model.py:145 -msgid "run work productivity valuation" -msgstr "ejecutar la valoración de la productividad del trabajo" - -#: src/natcap/invest/urban_cooling_model.py:147 -msgid "Run the work productivity valuation model." -msgstr "Ejecutar el modelo de valoración de la productividad del trabajo." - -#: src/natcap/invest/urban_cooling_model.py:150 -msgid "average relative humidity" -msgstr "humedad relativa media" - -#: src/natcap/invest/urban_cooling_model.py:153 -msgid "" -"The average relative humidity over the time period of interest. Required if " -"Run Work Productivity Valuation is selected." -msgstr "" -"La humedad relativa media durante el período de tiempo de interés. Requerida " -"si se selecciona la opción de ejecutar valoración de la productividad del " -"trabajo." - -#: src/natcap/invest/urban_cooling_model.py:159 -msgid "buildings" -msgstr "construcciones" - -#: src/natcap/invest/urban_cooling_model.py:164 -msgid "" -"Code indicating the building type. These codes must match those in the Energy " -"Consumption Table." -msgstr "" -"Código que indica el tipo de construcción. Estos códigos deben coincidir con " -"los de la tabla de consumo energético." - -#: src/natcap/invest/urban_cooling_model.py:169 -msgid "" -"A map of built infrastructure footprints. Required if Run Energy Savings " -"Valuation is selected." -msgstr "" -"Un mapa de las huellas de las infraestructuras construidas. Se necesita si se " -"selecciona la opción de ejecutar valoración del ahorro de energía." - -#: src/natcap/invest/urban_cooling_model.py:174 -msgid "energy consumption table" -msgstr "tabla de consumo de energía" - -#: src/natcap/invest/urban_cooling_model.py:179 -#, fuzzy -msgid "Building type codes matching those in the Buildings vector." -msgstr "" -"Códigos de tipo de construcción que coinciden con los del vector Buildings." - -#: src/natcap/invest/urban_cooling_model.py:186 -msgid "Energy consumption by footprint area for this building type." -msgstr "" -"Consumo de energía por superficie de la huella para este tipo de construcción." - -#: src/natcap/invest/urban_cooling_model.py:194 -msgid "" -"The cost of electricity for this building type. If this column is provided, " -"the energy savings outputs will be in the this currency unit rather than kWh." -msgstr "" -"El costo de la electricidad para este tipo de construcción. Si se proporciona " -"esta columna, los resultados de ahorro de energía estarán en esta unidad " -"monetaria en lugar de en kWh." - -#: src/natcap/invest/urban_cooling_model.py:202 -msgid "" -"A table of energy consumption data for each building type. Required if Run " -"Energy Savings Valuation is selected." -msgstr "" -"Una tabla de datos de consumo de energía para cada tipo de construcción. Se " -"necesita si se selecciona la opción de ejecutar la valoración del ahorro de " -"energía." - -#: src/natcap/invest/urban_cooling_model.py:207 -msgid "cooling capacity calculation method" -msgstr "método de cálculo de la capacidad de enfriamiento" - -#: src/natcap/invest/urban_cooling_model.py:211 -msgid "factors" -msgstr "factores" - -#: src/natcap/invest/urban_cooling_model.py:212 -#, fuzzy -msgid "" -"Use the weighted shade, albedo, and ETI factors as a temperature predictor " -"(for daytime temperatures)." -msgstr "" -"Utilizar los factores ponderados de sombra, albedo e IET como predictor de " -"temperatura (para las temperaturas diurnas)." - -#: src/natcap/invest/urban_cooling_model.py:216 -msgid "intensity" -msgstr "intensidad" - -#: src/natcap/invest/urban_cooling_model.py:217 -msgid "" -"Use building intensity as a temperature predictor (for nighttime temperatures)." -msgstr "" -"Utilizar la intensidad de construcción como predictor de la temperatura (para " -"las temperaturas nocturnas)." - -#: src/natcap/invest/urban_cooling_model.py:221 -msgid "The air temperature predictor method to use." -msgstr "El método de predicción de la temperatura del aire a utilizar." - -#: src/natcap/invest/urban_cooling_model.py:224 -msgid "shade weight" -msgstr "peso de la sombra" - -#: src/natcap/invest/urban_cooling_model.py:227 -msgid "" -"The relative weight to apply to shade when calculating the cooling capacity " -"index. If not provided, defaults to 0.6." -msgstr "" -"La ponderación relativa que se aplica a la sombra cuando se calcula el índice " -"de capacidad de enfriamiento. Si no se proporciona, el valor predeterminado es " -"0.6." - -#: src/natcap/invest/urban_cooling_model.py:232 -msgid "albedo weight" -msgstr "poneración del albedo" - -#: src/natcap/invest/urban_cooling_model.py:235 -msgid "" -"The relative weight to apply to albedo when calculating the cooling capacity " -"index. If not provided, defaults to 0.2." -msgstr "" -"La ponderación relativa que se aplica al albedo cuando se calcula el índice de " -"capacidad de enfriamiento. Si no se proporciona, el valor predeterminado es " -"0.2." - -#: src/natcap/invest/urban_cooling_model.py:240 -msgid "evapotranspiration weight" -msgstr "ponderación de la evapotranspiración" - -#: src/natcap/invest/urban_cooling_model.py:243 -msgid "" -"The relative weight to apply to ETI when calculating the cooling capacity " -"index. If not provided, defaults to 0.2." -msgstr "" -"La ponderación relativa que se aplicará al IET cuando se calcule el índice de " -"capacidad de enfriamiento. Si no se proporciona, el valor predeterminado es " -"0.2." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:44 -msgid "Depth of rainfall for the design storm of interest." -msgstr "" -"Profundidad de las precipitaciones para la tormenta de diseño de interés." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:45 -msgid "rainfall depth" -msgstr "profundidad de la precipitación" - -#: src/natcap/invest/urban_flood_risk_mitigation.py:50 -msgid "" -"Map of LULC. All values in this raster must have corresponding entries in the " -"Biophysical Table." -msgstr "" -"Mapa de LULC. Todos los valores de este ráster deben tener los inputs " -"correspondientes en la tabla biofísica." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:63 -msgid "LULC codes matching those in the LULC map." -msgstr "Códigos LULC que coinciden con los del mapa LULC." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:65 -msgid "The curve number value for this LULC type in the soil group code" -msgstr "" -"El valor del número de curva para este tipo de LULC en el código de grupo de " -"suelos" - -#: src/natcap/invest/urban_flood_risk_mitigation.py:70 -msgid "" -"Table of curve number data for each LULC class. All LULC codes in the LULC " -"raster must have corresponding entries in this table for each soil group." -msgstr "" -"Tabla de datos del número de curva para cada clase LULC. Todos los códigos " -"LULC en el raster LULC deben tener los inputs correspondientes en esta tabla " -"para cada grupo de suelos." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:81 -#, fuzzy -msgid "" -"Code indicating the building type. These codes must match those in the Damage " -"Loss Table." -msgstr "" -"Código que indica el tipo de construcción. Estos códigos deben coincidir con " -"los de la Tabla de Pérdidas por Daños." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:87 -msgid "Map of building footprints." -msgstr "Mapa de las huellas de las construcciones." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:88 -msgid "built infrastructure" -msgstr "infraestructura construida" - -#: src/natcap/invest/urban_flood_risk_mitigation.py:95 -msgid "Building type code." -msgstr "Código de tipo de construcción." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:99 -msgid "Potential damage loss for this building type." -msgstr "Pérdida potencial de daños para este tipo de construcción." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:102 -msgid "" -"Table of potential damage loss data for each building type. All values in the " -"Built Infrastructure vector 'type' field must have corresponding entries in " -"this table. Required if the Built Infrastructure vector is provided." -msgstr "" -"Tabla de datos de pérdidas de daños potenciales para cada tipo de " -"construcción. Todos los valores del campo \"tipo\" del vector Infraestructura " -"construida deben tener los inputs correspondientes en esta tabla. Obligatorio " -"si se proporciona el vector Infraestructura construida." - -#: src/natcap/invest/urban_flood_risk_mitigation.py:107 -msgid "damage loss table" -msgstr "tabla de pérdidas por daños" - -#: src/natcap/invest/validation.py:30 -#, fuzzy -msgid "Key is missing from the args dict" -msgstr "Falta la clave en el dictado de args" - -#: src/natcap/invest/validation.py:31 -msgid "Input is required but has no value" -msgstr "El input es necesario pero no tiene valor" - -#: src/natcap/invest/validation.py:32 -msgid "Expected the {header} \"{header_name}\" but did not find it" -msgstr "Esperaba el {header} \"{header_name}\" pero no lo encontró" - -#: src/natcap/invest/validation.py:34 -msgid "" -"Expected the {header} \"{header_name}\" only once but found it {number} times" -msgstr "" -"Esperaba el {header} \"{header_name}\" solo una vez pero lo encontró {number} " -"veces" - -#: src/natcap/invest/validation.py:36 -#, fuzzy -msgid "Value \"{value}\" could not be interpreted as a number" -msgstr "El valor \"{value}\" no pudo ser interpretado como un número" - -#: src/natcap/invest/validation.py:37 -#, fuzzy -msgid "" -"Layer must be projected in this unit: \"{unit_a}\" but found this unit: " -"\"{unit_b}\"" -msgstr "" -"La capa debe ser proyectada en esta unidad: \"{unit_a}\" pero se ha encontrado " -"esta unidad: \"{unit_b}\"" - -#: src/natcap/invest/validation.py:39 -msgid "An unexpected error occurred in validation" -msgstr "Se ha producido un error inesperado en la validación" - -#: src/natcap/invest/validation.py:40 -msgid "Directory not found" -msgstr "Directorio no encontrado" - -#: src/natcap/invest/validation.py:41 -msgid "Path must be a directory" -msgstr "La ruta debe ser un directorio" - -#: src/natcap/invest/validation.py:42 -msgid "File not found" -msgstr "Archivo no encontrado" - -#: src/natcap/invest/validation.py:43 -msgid "Dataset must have a valid projection." -msgstr "El conjunto de datos debe tener una proyección válida." - -#: src/natcap/invest/validation.py:44 -msgid "Dataset must be projected in linear units." -msgstr "El conjunto de datos debe proyectarse en unidades lineales." - -#: src/natcap/invest/validation.py:45 -msgid "File could not be opened as a GDAL raster" -msgstr "No se ha podido abrir el archivo como un ráster GDAL" - -#: src/natcap/invest/validation.py:46 -msgid "File found to be an overview \".ovr\" file." -msgstr "Se ha encontrado que el archivo es un archivo de resumen \".ovr\"." - -#: src/natcap/invest/validation.py:47 -msgid "File could not be opened as a GDAL vector" -msgstr "No se ha podido abrir el archivo como vector GDAL" - -#: src/natcap/invest/validation.py:48 -msgid "File could not be opened as a CSV or Excel file." -msgstr "El archivo no pudo abrirse como un archivo CSV o Excel." - -#: src/natcap/invest/validation.py:49 -msgid "File could not be opened as a CSV. File must be encoded as a UTF-8 CSV." -msgstr "" -"El archivo no se ha podido abrir como CSV. El archivo debe estar codificado " -"como un CSV UTF-8." - -#: src/natcap/invest/validation.py:51 -#, fuzzy -msgid "Value did not match expected pattern {regexp}" -msgstr "El valor no coincide con el patrón esperado {regexp}" - -#: src/natcap/invest/validation.py:52 -#, fuzzy -msgid "Value must be one of: {option_list}" -msgstr "El valor debe ser uno de: {option_list}" - -#: src/natcap/invest/validation.py:53 -#, fuzzy -msgid "Value does not meet condition {condition}" -msgstr "El valor no cumple la condición {condition}" - -#: src/natcap/invest/validation.py:54 -#, fuzzy -msgid "Value {value} is not in the range {range}" -msgstr "El valor {value} no está en el rango {range}" - -#: src/natcap/invest/validation.py:55 -#, fuzzy -msgid "Value \"{value}\" does not represent an integer" -msgstr "El valor \"{value}\" no representa un entero" - -#: src/natcap/invest/validation.py:56 -#, fuzzy -msgid "Value must be either True or False, not {value}" -msgstr "El valor debe ser Verdadero o Falso, no {value}" - -#: src/natcap/invest/validation.py:57 -#, fuzzy -msgid "Spatial file {filepath} has no projection" -msgstr "El archivo espacial {filepath} no tiene proyección" - -#: src/natcap/invest/validation.py:58 -#, fuzzy -msgid "Bounding boxes do not intersect: {bboxes}" -msgstr "Las cajas delimitadoras no se cruzan: {bboxes}" - -#: src/natcap/invest/validation.py:59 -#, fuzzy -msgid "You must have {permission} access to this file" -msgstr "Debe tener acceso {permission} a este archivo" - -#: src/natcap/invest/wave_energy.py:45 -msgid "Point vector for the west coast of North America and Hawaii." -msgstr "Vector de puntos para la costa oeste de América del Norte y Hawái." - -#: src/natcap/invest/wave_energy.py:52 -msgid "Extract vector for the west coast of North America and Hawaii." -msgstr "Vector de extracción para la costa oeste de América del Norte y Hawái." - -#: src/natcap/invest/wave_energy.py:57 -msgid "WaveWatchIII data for the west coast of North America and Hawaii." -msgstr "Datos de WaveWatchIII para la costa oeste de Norteamérica y Hawai." - -#: src/natcap/invest/wave_energy.py:64 -msgid "Point vector for the East Coast of North America and Puerto Rico." -msgstr "Vector de puntos para la costa este de Norteamérica y Puerto Rico." - -#: src/natcap/invest/wave_energy.py:71 -msgid "Extract vector for the East Coast of North America and Puerto Rico." -msgstr "Vector de extracción para la costa este de Norteamérica y Puerto Rico." - -#: src/natcap/invest/wave_energy.py:76 -msgid "WaveWatchIII data for the East Coast of North America and Puerto Rico." -msgstr "Datos de WaveWatchIII para la costa este de Norteamérica y Puerto Rico." - -#: src/natcap/invest/wave_energy.py:83 -msgid "Point vector for the North Sea 4 meter resolution." -msgstr "Vector de puntos para el Mar del Norte con una resolución de 4 metros." - -#: src/natcap/invest/wave_energy.py:89 -msgid "Extract vector for the North Sea 4 meter resolution." -msgstr "" -"Vector de extracción para el Mar del Norte con una resolución de 4 metros." - -#: src/natcap/invest/wave_energy.py:93 -msgid "WaveWatchIII data for the North Sea 4 meter resolution." -msgstr "" -"Datos de WaveWatchIII para el Mar del Norte con una resolución de 4 metros." - -#: src/natcap/invest/wave_energy.py:100 -msgid "Point vector for the North Sea 10 meter resolution." -msgstr "Vector de puntos para el Mar del Norte con una resolución de 10 metros." - -#: src/natcap/invest/wave_energy.py:106 -msgid "Extract vector for the North Sea 10 meter resolution." -msgstr "" -"Vector de extracción para el Mar del Norte con una resolución de 10 metros." - -#: src/natcap/invest/wave_energy.py:110 -msgid "WaveWatchIII data for the North Sea 10 meter resolution." -msgstr "" -"Datos de WaveWatchIII para el Mar del Norte con una resolución de 10 metros." - -#: src/natcap/invest/wave_energy.py:117 -msgid "Point vector for Australia." -msgstr "Vector de puntos para Australia." - -#: src/natcap/invest/wave_energy.py:122 -msgid "Extract vector for Australia." -msgstr "Extraer el vector para Australia." - -#: src/natcap/invest/wave_energy.py:125 -msgid "WaveWatchIII data for Australia." -msgstr "Datos de WaveWatchIII para Australia." - -#: src/natcap/invest/wave_energy.py:130 -msgid "Global point vector." -msgstr "Vector global de puntos." - -#: src/natcap/invest/wave_energy.py:135 -msgid "Global extract vector." -msgstr "Vector de extracción global." - -#: src/natcap/invest/wave_energy.py:138 -msgid "Global WaveWatchIII data." -msgstr "Datos de Global WaveWatchIII." - -#: src/natcap/invest/wave_energy.py:140 -msgid "" -"Pre-packaged wave energy data directory. This is provided with the sample data." -msgstr "" -"Directorio de datos de energía de las olas preempaquetado. Se proporciona con " -"los datos de muestra." - -#: src/natcap/invest/wave_energy.py:143 -msgid "wave base data" -msgstr "datos base de las olas" - -#: src/natcap/invest/wave_energy.py:148 -msgid "West Coast of North America and Hawaii" -msgstr "Costa Oeste de América del Norte y Hawái" - -#: src/natcap/invest/wave_energy.py:150 -msgid "East Coast of North America and Puerto Rico" -msgstr "Costa Este de Norteamérica y Puerto Rico" - -#: src/natcap/invest/wave_energy.py:153 -msgid "North Sea 4 meter resolution" -msgstr "Resolución de 4 metros de en el Mar del Norte" - -#: src/natcap/invest/wave_energy.py:155 -msgid "North Sea 10 meter resolution" -msgstr "Resolución de 10 metros en el Mar del Norte" - -#: src/natcap/invest/wave_energy.py:156 -msgid "Australia" -msgstr "Australia" - -#: src/natcap/invest/wave_energy.py:157 -msgid "Global" -msgstr "Global" - -#: src/natcap/invest/wave_energy.py:159 -msgid "The analysis area over which to run the model." -msgstr "El área de análisis sobre la que se ejecutará el modelo." - -#: src/natcap/invest/wave_energy.py:161 -msgid "analysis area" -msgstr "área de análisis" - -#: src/natcap/invest/wave_energy.py:171 -msgid "" -"A matrix of the wave machine performance, or ability to capture wave energy, " -"in different sea state conditions. The first column contains wave height " -"values (in meters, increasing from top to bottom), and the first row contains " -"wave period values (in seconds, increasing from left to right). Values within " -"the matrix are the machine performance in kilowatts at that sea state " -"condition, described by the wave height (row) and wave period (column). The " -"model linearly interpolates sea state data from the base wave dataset onto " -"this matrix to determine performance." -msgstr "" -"Una matriz del rendimiento de la máquina de olas, o de la capacidad de captar " -"la energía de las olas, en diferentes condiciones del estado del mar. La " -"primera columna contiene los valores de la altura de las olas (en metros, " -"aumentando de arriba hacia abajo), y la primera fila contiene los valores del " -"periodo de las olas (en segundos, aumentando de izquierda a derecha). Los " -"valores dentro de la matriz son el rendimiento de la máquina en kilovatios en " -"esa condición de estado del mar, descrita por la altura de la ola (fila) y el " -"período de la ola (columna). El modelo interpola linealmente los datos del " -"estado del mar del conjunto de datos de olas base en esta matriz para " -"determinar el rendimiento." - -#: src/natcap/invest/wave_energy.py:182 -msgid "machine performance table" -msgstr "tabla de rendimiento de la máquina" - -#: src/natcap/invest/wave_energy.py:188 -msgid "Maximum capacity for device." -msgstr "Capacidad máxima del dispositivo." - -#: src/natcap/invest/wave_energy.py:193 -msgid "" -"Upper limit of wave height for device operation. The device shuts down when " -"waves are higher than this." -msgstr "" -"Límite superior de la altura de las olas para el funcionamiento del " -"dispositivo. El dispositivo se apaga cuando las olas son más altas que esto." - -#: src/natcap/invest/wave_energy.py:200 -msgid "" -"Upper limit of wave period for device operation. The device shuts down when " -"the wave period is longer than this." -msgstr "" -"Límite superior del periodo de onda para el funcionamiento del aparato. El " -"dispositivo se apaga cuando el periodo de onda es mayor que este." - -#: src/natcap/invest/wave_energy.py:208 -msgid "Table of parameters for the wave energy machine in use." -msgstr "Tabla de parámetros de la máquina de energía de las olas en uso." - -#: src/natcap/invest/wave_energy.py:209 -msgid "machine parameter table" -msgstr "tabla de parámetros de la máquina" - -#: src/natcap/invest/wave_energy.py:212 src/natcap/invest/wind_energy.py:100 -msgid "bathymetry" -msgstr "batimetría" - -#: src/natcap/invest/wave_energy.py:215 src/natcap/invest/wind_energy.py:99 -msgid "Map of ocean depth. Values should be negative." -msgstr "Mapa de la profundidad del océano. Los valores deben ser negativos." - -#: src/natcap/invest/scenic_quality/scenic_quality.py:123 -#: src/natcap/invest/wave_energy.py:220 -msgid "Run the valuation model." -msgstr "Ejecutar el modelo de valoración." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:348 -#: src/natcap/invest/scenic_quality/scenic_quality.py:120 -#: src/natcap/invest/wave_energy.py:221 src/natcap/invest/wind_energy.py:282 -msgid "run valuation" -msgstr "ejecutar validación" - -#: src/natcap/invest/wave_energy.py:228 src/natcap/invest/wind_energy.py:302 -msgid "Unique identifier for each point." -msgstr "Identificador único para cada punto." - -#: src/natcap/invest/wave_energy.py:232 src/natcap/invest/wind_energy.py:306 -msgid "This is a land connection point" -msgstr "Este es un punto de conexión terrestre" - -#: src/natcap/invest/wave_energy.py:234 src/natcap/invest/wind_energy.py:308 -msgid "This is a grid connection point" -msgstr "Este es un punto de conexión a la cuadrícula" - -#: src/natcap/invest/wave_energy.py:237 src/natcap/invest/wind_energy.py:311 -msgid "The type of connection at this point." -msgstr "El tipo de conexión en este punto." - -#: src/natcap/invest/wave_energy.py:242 src/natcap/invest/wind_energy.py:316 -msgid "Latitude of the connection point." -msgstr "Latitud del punto de conexión." - -#: src/natcap/invest/wave_energy.py:247 src/natcap/invest/wind_energy.py:321 -msgid "Longitude of the connection point." -msgstr "Longitud del punto de conexión." - -#: src/natcap/invest/wave_energy.py:251 -msgid "Name for the connection point location." -msgstr "Nombre de la ubicación del punto de conexión." - -#: src/natcap/invest/wave_energy.py:255 -msgid "" -"A table of data for each connection point. Required if Run Valuation is " -"selected." -msgstr "" -"Una tabla de datos para cada punto de conexión. Se requiere si se selecciona " -"la opción de ejecución de la validación." - -#: src/natcap/invest/wave_energy.py:258 -msgid "grid connection points table" -msgstr "tabla de puntos de conexión a la cuadrícula" - -#: src/natcap/invest/wave_energy.py:266 -msgid "Maximum capacity of the device." -msgstr "Capacidad máxima del dispositivo." - -#: src/natcap/invest/wave_energy.py:271 -msgid "Capital cost per device installed." -msgstr "Costo de capital por dispositivo instalado." - -#: src/natcap/invest/wave_energy.py:276 -msgid "Cost of mooring lines." -msgstr "Costo de los cabos de amarre." - -#: src/natcap/invest/wave_energy.py:281 -msgid "Cost of underwater cable." -msgstr "Costo del cable submarino." - -#: src/natcap/invest/wave_energy.py:286 -msgid "Cost of overland transmission lines." -msgstr "Costo de las líneas de transmisión terrestre." - -#: src/natcap/invest/wave_energy.py:291 -msgid "Operating and maintenance cost." -msgstr "Costo de funcionamiento y mantenimiento." - -#: src/natcap/invest/wave_energy.py:296 -msgid "Price of electricity." -msgstr "Precio de la electricidad." - -#: src/natcap/invest/wave_energy.py:300 -msgid "Discount rate." -msgstr "Tasa de descuento." - -#: src/natcap/invest/wave_energy.py:305 -msgid "Number of slack lines required per machine." -msgstr "Número de líneas de holgura necesarias por máquina." - -#: src/natcap/invest/wave_energy.py:310 -msgid "" -"Table of economic parameters for the wave energy machine. Required if Run " -"Valuation is selected." -msgstr "" -"Tabla de parámetros económicos de la máquina de energía de las olas. Se " -"requiere si se selecciona la opción de ejecución de la valoración." - -#: src/natcap/invest/wave_energy.py:313 -msgid "machine economic table" -msgstr "cuadro económico de la máquina" - -#: src/natcap/invest/wave_energy.py:320 -msgid "Number of wave machines to model. Required if Run Valuation is selected." -msgstr "" -"Número de máquinas de olas a modelizar. Es necesario si se selecciona la " -"opción de ejecución de la validación." - -#: src/natcap/invest/wave_energy.py:323 -msgid "number of machines" -msgstr "número de máquinas" - -#: src/natcap/invest/wind_energy.py:55 -msgid "Longitude of the data point." -msgstr "Longitud del punto de datos." - -#: src/natcap/invest/wind_energy.py:60 -msgid "Latitude of the data point." -msgstr "Latitud del punto de datos." - -#: src/natcap/invest/wind_energy.py:65 -msgid "Weibull scale factor at the reference hub height at this point." -msgstr "" -"Factor de escala de Weibull en la altura del buje de referencia en este punto." - -#: src/natcap/invest/wind_energy.py:72 -msgid "Weibull shape factor at this point." -msgstr "Factor de forma de Weibull en este punto." - -#: src/natcap/invest/wind_energy.py:77 -#, fuzzy -msgid "" -"The reference hub height at this point, at which wind speed data was collected " -"and LAM was estimated." -msgstr "" -"La altura del buje de referencia en este punto, en el que se recogieron los " -"datos de la velocidad del viento y se estimó el LAM." - -#: src/natcap/invest/wind_energy.py:82 -msgid "Table of Weibull parameters for each wind data point." -msgstr "Tabla de parámetros de Weibull para cada punto de datos de viento." - -#: src/natcap/invest/wind_energy.py:83 -msgid "wind data points" -msgstr "puntos de datos del viento" - -#: src/natcap/invest/wind_energy.py:90 -msgid "" -"Map of the area(s) of interest over which to run the model and aggregate " -"valuation results. Required if Run Valuation is selected and the Grid " -"Connection Points table is provided." -msgstr "" -"Mapa de la(s) zona(s) de interés sobre la(s) cual(es) se ejecuta el modelo y " -"se agregan los resultados de la valoración. Se requiere si se selecciona la " -"opción de ejecutar valoración y se proporciona la tabla de Puntos de conexión " -"a la cuadrícula." - -#: src/natcap/invest/wind_energy.py:107 -msgid "" -"Map of the coastlines of landmasses in the area of interest. Required if the " -"Minimum Distance and Maximum Distance inputs are provided." -msgstr "" -"Mapa de las líneas de costa de las masas de tierra en el área de interés. Se " -"requiere si se proporcionan los inputs de Distancia mínima y Distancia máxima." - -#: src/natcap/invest/wind_energy.py:111 -msgid "land polygon" -msgstr "polígono de tierra" - -#: src/natcap/invest/wind_energy.py:119 -msgid "Standard atmosphere air density." -msgstr "Densidad del aire de la atmósfera estándar." - -#: src/natcap/invest/wind_energy.py:123 -msgid "Exponent to use in the power curve function." -msgstr "Exponente a utilizar en la función de la curva de potencia." - -#: src/natcap/invest/wind_energy.py:126 -msgid "" -"Cost to decommission a turbine as a proportion of the total upfront costs " -"(cables, foundations, installation?)" -msgstr "" -"Costo de desmantelamiento de una turbina en proporción a los costos iniciales " -"totales (cables, cimientos, instalación...)" - -#: src/natcap/invest/wind_energy.py:133 -msgid "The operations and maintenance costs as a proportion of capex_arr" -msgstr "Los costes de operación y mantenimiento como proporción del capex_arr" - -#: src/natcap/invest/wind_energy.py:138 -msgid "The miscellaneous costs as a proportion of capex_arr" -msgstr "Los gastos misceláneos como proporción de capex_arr" - -#: src/natcap/invest/wind_energy.py:143 -msgid "The installation costs as a proportion of capex_arr" -msgstr "Los costes de instalación como proporción del capex_arr" - -#: src/natcap/invest/wind_energy.py:149 -msgid "The length of infield cable." -msgstr "La longitud del cableado interior." - -#: src/natcap/invest/wind_energy.py:153 -msgid "The cost of infield cable." -msgstr "El costo del cableado interior." - -#: src/natcap/invest/wind_energy.py:157 -msgid "Cost of AC cable that scales with capacity." -msgstr "Costo del cable de corriente alterna que se adapta a la capacidad." - -#: src/natcap/invest/wind_energy.py:161 -msgid "Cost of DC cable that scales with capacity." -msgstr "Costo del cable de corriente continua que se adapta a la capacidad." - -#: src/natcap/invest/wind_energy.py:165 -msgid "Cost of AC cable that scales with length." -msgstr "Costo del cable de corriente alterna que aumenta con la longitud." - -#: src/natcap/invest/wind_energy.py:169 -msgid "Cost of DC cable that scales with length." -msgstr "Costo del cable de corriente continua que aumenta con la longitud." - -#: src/natcap/invest/wind_energy.py:173 -msgid "" -"The threshold above which a wind farm’s distance from the grid requires a " -"switch from AC to DC power to overcome line losses which reduce the amount of " -"energy delivered" -msgstr "" -"El umbral a partir del cual la distancia de un parque eólico a la red requiere " -"un cambio de CA a CC para superar las pérdidas de la línea que reducen la " -"cantidad de energía suministrada" - -#: src/natcap/invest/wind_energy.py:181 -msgid "The expected lifetime of the facility" -msgstr "La vida útil prevista de la instalación" - -#: src/natcap/invest/wind_energy.py:185 -msgid "" -"Factor that translates carbon-free wind power to a corresponding amount of " -"avoided CO2 emissions" -msgstr "" -"Factor que traduce la energía eólica libre de carbono en una cantidad " -"correspondiente de emisiones de CO2 evitadas" - -#: src/natcap/invest/wind_energy.py:191 -msgid "The reduction in air density per meter above sea level" -msgstr "La reducción de la densidad del aire por metro sobre el nivel del mar" - -#: src/natcap/invest/wind_energy.py:196 -msgid "" -"The fraction of energy lost due to downtime, power conversion inefficiency, " -"and electrical grid losses" -msgstr "" -"La fracción de energía que se pierde debido al tiempo de inactividad, la " -"ineficiencia de la conversión de energía y las pérdidas de la red eléctrica" - -#: src/natcap/invest/wind_energy.py:200 -msgid "A table of wind energy infrastructure parameters." -msgstr "Tabla de parámetros de la infraestructura de la energía eólica." - -#: src/natcap/invest/wind_energy.py:202 -msgid "global wind energy parameters" -msgstr "parámetros globales de la energía eólica" - -#: src/natcap/invest/wind_energy.py:210 -msgid "Height of the turbine hub above sea level." -msgstr "Altura del buje de la turbina sobre el nivel del mar." - -#: src/natcap/invest/wind_energy.py:214 -msgid "Wind speed at which the turbine begins producing power." -msgstr "Velocidad del viento a la que la turbina empieza a producir energía." - -#: src/natcap/invest/wind_energy.py:220 -msgid "Minimum wind speed at which the turbine reaches its rated power output." -msgstr "" -"Velocidad mínima del viento a la que la turbina alcanza su potencia nominal." - -#: src/natcap/invest/wind_energy.py:226 -msgid "" -"Wind speed above which the turbine stops generating power for safety reasons." -msgstr "" -"Velocidad del viento por encima de la cual la turbina deja de generar energía " -"por razones de seguridad." - -#: src/natcap/invest/wind_energy.py:232 -msgid "The turbine's rated power output." -msgstr "La potencia nominal de la turbina." - -#: src/natcap/invest/wind_energy.py:236 -msgid "The cost of one turbine." -msgstr "El coste de una turbina." - -#: src/natcap/invest/wind_energy.py:238 -msgid "A table of parameters specific to the type of turbine." -msgstr "Una tabla de parámetros específicos para el tipo de turbina." - -#: src/natcap/invest/wind_energy.py:239 -msgid "turbine parameters" -msgstr "parámetros de la turbina" - -#: src/natcap/invest/wind_energy.py:245 -msgid "The number of wind turbines per wind farm." -msgstr "El número de aerogeneradores por parque eólico." - -#: src/natcap/invest/wind_energy.py:246 -msgid "number of turbines" -msgstr "número de turbinas" - -#: src/natcap/invest/wind_energy.py:251 -msgid "Minimum depth for offshore wind farm installation." -msgstr "Profundidad mínima para la instalación de parques eólicos en alta mar." - -#: src/natcap/invest/wind_energy.py:252 -msgid "minimum depth" -msgstr "profundidad mínima" - -#: src/natcap/invest/wind_energy.py:257 -msgid "Maximum depth for offshore wind farm installation." -msgstr "Profundidad máxima para la instalación de parques eólicos en alta mar." - -#: src/natcap/invest/wind_energy.py:258 -msgid "maximum depth" -msgstr "profundidad máxima" - -#: src/natcap/invest/wind_energy.py:264 -msgid "" -"Minimum distance from shore for offshore wind farm installation. Required if " -"Run Valuation is selected." -msgstr "" -"Distancia mínima desde la costa para la instalación de un parque eólico " -"marino. Se necesita si se selecciona la opción de ejecución de valoración." - -#: src/natcap/invest/wind_energy.py:267 -msgid "minimum distance" -msgstr "distancia mínima" - -#: src/natcap/invest/wind_energy.py:273 -msgid "" -"Maximum distance from shore for offshore wind farm installation. Required if " -"Run Valuation is selected." -msgstr "" -"Distancia máxima desde la costa para la instalación del parque eólico marino. " -"Se necesita si se selecciona la opción de ejecución de evaluación." - -#: src/natcap/invest/wind_energy.py:276 -msgid "maximum distance" -msgstr "distancia máxima" - -#: src/natcap/invest/wind_energy.py:281 -msgid "Run the valuation component of the model." -msgstr "Ejecute el componente de valoración del modelo." - -#: src/natcap/invest/wind_energy.py:288 -msgid "The cost of the foundation for one turbine." -msgstr "El coste de los cimientos de una turbina." - -#: src/natcap/invest/wind_energy.py:289 -msgid "foundation cost" -msgstr "coste de la cimentación" - -#: src/natcap/invest/wind_energy.py:294 -msgid "Annual discount rate to apply to valuation." -msgstr "Tasa de descuento anual a aplicar en la valoración." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:402 -#: src/natcap/invest/wind_energy.py:295 -msgid "discount rate" -msgstr "tasa de descuento" - -#: src/natcap/invest/wind_energy.py:325 -msgid "" -"Table of grid and land connection points to which cables will connect. " -"Required if Run Valuation is selected and Average Shore-to-Grid Distance is " -"not provided." -msgstr "" -"Tabla de puntos de conexión a la red y a tierra a los que se conectarán los " -"cables. Necesario si se selecciona la opción de valoración de la ejecución y " -"no se proporciona la distancia media de la orilla a la red." - -#: src/natcap/invest/wind_energy.py:329 -msgid "grid connection points" -msgstr "puntos de conexión a la cuadrícula" - -#: src/natcap/invest/wind_energy.py:336 -#, fuzzy -msgid "" -"Average distance to the onshore grid from coastal cable landing points. " -"Required if Run Valuation is selected and the Grid Connection Points table is " -"not provided." -msgstr "" -"Distancia media a la red terrestre desde los puntos de desembarco del cable " -"costero. Necesario si se selecciona la opción de valoración de la ejecución y " -"no se proporciona la tabla de Puntos de conexión a la red." - -#: src/natcap/invest/wind_energy.py:340 -msgid "average shore-to-grid distance" -msgstr "distancia media entre la costa y la red" - -#: src/natcap/invest/wind_energy.py:345 -msgid "" -"Use a Wind Energy Price Table instead of calculating annual prices from the " -"initial Energy Price and Rate of Price Change inputs." -msgstr "" -"Utilizar una tabla de precios de la energía eólica en lugar de calcular los " -"precios anuales a partir de los inputs iniciales del precio de la energía y " -"la tasa de variación del precio." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:357 -#: src/natcap/invest/wind_energy.py:349 -msgid "use price table" -msgstr "utilizar la tabla de precios" - -#: src/natcap/invest/wind_energy.py:357 -msgid "" -"Consecutive years for each year in the lifespan of the wind farm. These may be " -"the actual years: 2010, 2011, 2012..., or the number of the years after the " -"starting date: 1, 2, 3,..." -msgstr "" -"Años consecutivos para cada año de la vida útil del parque eólico. Pueden ser " -"los años reales: 2010, 2011, 2012..., o el número de los años posteriores a la " -"fecha de inicio: 1, 2, 3,..." - -#: src/natcap/invest/wind_energy.py:366 -msgid "Price of energy for each year." -msgstr "Precio de la energía para cada año." - -#: src/natcap/invest/wind_energy.py:370 -msgid "" -"Table of yearly prices for wind energy. There must be a row for each year in " -"the lifespan given in the 'time_period' column in the Global Wind Energy " -"Parameters table. Required if Run Valuation and Use Price Table are selected." -msgstr "" -"Tabla de precios anuales de la energía eólica. Debe haber una fila por cada " -"año de la vida útil indicada en la columna \"time_period\" de la tabla Global " -"Wind Energy Parameters. Se requiere si se seleccionan las opciones de " -"valoración de la ejecución y la de utilización de la Tabla de precios." - -#: src/natcap/invest/wind_energy.py:375 -msgid "wind energy price table" -msgstr "tabla de precios de la energía eólica" - -#: src/natcap/invest/wind_energy.py:381 -#, fuzzy -msgid "" -"The initial price of wind energy, at the first year in the wind energy farm " -"lifespan. Required if Run Valuation is selected and Use Price Table is not " -"selected." -msgstr "" -"El precio inicial de la energía eólica, en el primer año de la vida útil del " -"parque eólico. Requerido si se seleccionan las opciones de valoración de " -"ejecución y no se selecciona la de utilizar Tabla de precios." - -#: src/natcap/invest/wind_energy.py:385 -msgid "price of energy" -msgstr "precio de la energía" - -#: src/natcap/invest/wind_energy.py:390 -#, fuzzy -msgid "" -"The annual rate of change in the price of wind energy. Required if Run " -"Valuation is selected and Use Price Table is not selected." -msgstr "" -"La tasa de variación anual del precio de la energía eólica. Requerido si se " -"selecciona la opción de ejecución de valoración y no se selecciona la de " -"utilización de la Tabla de precios." - -#: src/natcap/invest/wind_energy.py:394 -msgid "rate of price change" -msgstr "tasa de variación de los precios" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:115 -#, fuzzy -msgid "" -"Analysis year {analysis_year} must be >= the latest snapshot year " -"({latest_year})" -msgstr "" -"El año de análisis {analysis_year} debe ser >= el último año de la instantánea " -"({latest_year})" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:118 -#, fuzzy -msgid "Raster for snapshot {snapshot_year} could not be validated." -msgstr "No se ha podido validar la trama de la instantánea {snapshot_year}." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:174 -msgid "" -"The snapshot year that this row's LULC raster represents. Each year in this " -"table must be unique." -msgstr "" -"El año de la instantánea que representa el ráster LULC de esta fila. Cada año " -"de esta tabla debe ser único." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:181 -msgid "" -"Map of LULC in the given snapshot year. All values in this raster must have " -"corresponding entries in the Biophysical Table and Landcover Transitions Table." -msgstr "" -"Mapa de LULC en el año de la instantánea. Todos los valores de este ráster " -"deben tener los inputs correspondientes en la Tabla Biofísica y en la Tabla de " -"Transiciones de la Cubierta Terrestre." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:188 -msgid "A table mapping snapshot years to corresponding LULC maps." -msgstr "" -"Una tabla que relaciona los años de la instantánea con los mapas LULC " -"correspondientes." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:190 -msgid "landcover snapshots table" -msgstr "tabla de instantáneas de la cubierta vegetal" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:196 -msgid "analysis year" -msgstr "año de análisis" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:197 -msgid "" -"A year that may be used to extend the analysis beyond the last snapshot year. " -"If used, the model assumes that carbon will continue to accumulate or emit " -"after the last snapshot year until the analysis year. This value must be " -"greater than the final snapshot year." -msgstr "" -"Un año que puede utilizarse para ampliar el análisis más allá del último año " -"de la instantánea. Si se utiliza, el modelo asume que el carbono seguirá " -"acumulándose o emitiéndose después del último año de la instantánea hasta el " -"año de análisis. Este valor debe ser mayor que el último año de la instantánea." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:210 -msgid "" -"The LULC code that represents this LULC class in the LULC snapshot rasters." -msgstr "" -"El código LULC que representa esta clase LULC en los rastreos de instantáneas " -"LULC." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:215 -msgid "" -"Name of the LULC class. This label must be unique among the all the LULC " -"classes." -msgstr "" -"Nombre de la clase LULC. Esta etiqueta debe ser única entre todas las clases " -"LULC." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:221 -msgid "The initial carbon stocks in the biomass pool for this LULC class." -msgstr "" -"Las existencias iniciales de carbono en la reserva de biomasa para esta clase " -"de LULC." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:227 -msgid "The initial carbon stocks in the soil pool for this LULC class." -msgstr "" -"Las existencias iniciales de carbono en la reserva del suelo para esta clase " -"de LULC." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:233 -msgid "The initial carbon stocks in the litter pool for this LULC class." -msgstr "" -"Las existencias iniciales de carbono en la reserva de hojarasca para esta " -"clase de LULC." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:240 -msgid "The half-life of carbon in the biomass pool." -msgstr "La vida media del carbono en la reserva de biomasa." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:243 -msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a cell " -"transitions away from this LULC class in a low-impact disturbance." -msgstr "" -"Proporción de las existencias de carbono en la reserva de biomasa que se " -"perturba cuando una celda se aleja de esta clase de LULC en una perturbación " -"de bajo impacto." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:249 -msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a cell " -"transitions away from this LULC class in a medium-impact disturbance." -msgstr "" -"Proporción de las existencias de carbono en la reserva de biomasa que se ve " -"perturbada cuando una celda se aleja de esta clase de LULC en una perturbación " -"de impacto medio." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:255 -msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a cell " -"transitions away from this LULC class in a high-impact disturbance." -msgstr "" -"Proporción de las existencias de carbono en la reserva de biomasa que se " -"perturba cuando una celda se aleja de esta clase de LULC en una perturbación " -"de alto impacto." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:262 -msgid "Annual rate of CO2E accumulation in the biomass pool." -msgstr "Tasa anual de acumulación de CO2E en la reserva de biomasa." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:268 -msgid "The half-life of carbon in the soil pool." -msgstr "La vida media del carbono en la reserva del suelo." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:271 -msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell " -"transitions away from this LULC class in a low-impact disturbance." -msgstr "" -"Proporción de las existencias de carbono en la reserva de suelo que se " -"perturba cuando una celda se aleja de esta clase de LULC en una perturbación " -"de bajo impacto." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:277 -msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell " -"transitions away from this LULC class in a medium-impact disturbance." -msgstr "" -"Proporción de las existencias de carbono en la reserva de suelo que se " -"perturba cuando una celda se aleja de esta clase de LULC en una perturbación " -"de impacto medio." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:283 -msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell " -"transitions away from this LULC class in a high-impact disturbance." -msgstr "" -"Proporción de las existencias de carbono en la reserva de suelo que se " -"perturba cuando una célula se aleja de esta clase de LULC en una perturbación " -"de alto impacto." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:290 -msgid "Annual rate of CO2E accumulation in the soil pool." -msgstr "Tasa anual de acumulación de CO2E en la reserva del suelo." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:295 -msgid "Annual rate of CO2E accumulation in the litter pool." -msgstr "Tasa anual de acumulación de CO2E en la reserva de hojarasca." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:298 -msgid "Table of biophysical properties for each LULC class." -msgstr "Tabla de propiedades biofísicas para cada clase de LULC." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:301 -msgid "landcover transitions table" -msgstr "tabla de transiciones de la cubierta vegetal" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:306 -msgid "LULC codes matching the codes in the biophysical table." -msgstr "Códigos LULC que coinciden con los códigos de la tabla biofísica." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:313 -msgid "a state of carbon accumulation" -msgstr "un estado de acumulación de carbono" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:316 -msgid "high carbon disturbance rate" -msgstr "alto índice de perturbación del carbono" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:319 -msgid "medium carbon disturbance rate" -msgstr "índice de perturbación del carbono medio" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:322 -msgid "low carbon disturbance rate" -msgstr "bajo índice de perturbación del carbono" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:325 -msgid "no change in carbon" -msgstr "ningún cambio en el carbono" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:328 -#, fuzzy -msgid "" -"A transition matrix describing the type of carbon action that occurs when each " -"LULC type transitions to each other type. Values in the first column, 'lulc-" -"class', represents the original LULC class that is transitioned away from. " -"Values in the first row represents the LULC class that is transitioned to. " -"Each cell in the matrix is filled with an option indicating the effect on " -"carbon when transitioning from that cell's row's LULC class to that cell's " -"column's LULC class. The classes in this table must exactly match the classes " -"in the Biophysical Table 'lulc-class' column. A cell may be left empty if the " -"transition never occurs." -msgstr "" -"Una matriz de transición que describe el tipo de acción de carbono que se " -"produce cuando cada tipo de LULC hace la transición a otro tipo. Los valores " -"de la primera columna, \"lulc-class\", representan la clase LULC original de " -"la que se produce la transición. Los valores de la primera fila representan la " -"clase LULC a la que se produce la transición. Cada celda de la matriz se " -"rellena con una opción que indica el efecto sobre el carbono al pasar de la " -"clase LULC de la fila de esa celda a la clase LULC de la columna de esa celda. " -"Las clases de esta tabla deben coincidir exactamente con las clases de la " -"columna \"lulc-class\" de la tabla biofísica. Una celda puede dejarse vacía si " -"la transición no se produce nunca." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:343 -msgid "" -"A transition matrix mapping the type of carbon action undergone when one LULC " -"type transitions to another." -msgstr "" -"Una matriz de transición que mapea el tipo de acción del carbono que se " -"produce cuando un tipo de LULC transiciona a otro." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:351 -msgid "" -"Enable net present valuation analysis based on carbon prices from either a " -"yearly price table, or an initial price and yearly interest rate." -msgstr "" -"Permitir el análisis de la valoración actual neta basada en los precios del " -"carbono a partir de una tabla de precios anuales, o de un precio inicial y un " -"tipo de interés anual." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:360 -msgid "" -"Use a yearly price table, rather than an initial price and interest rate, to " -"indicate carbon value over time." -msgstr "" -"Utilice una tabla de precios anuales, en lugar de un precio inicial y un tipo " -"de interés, para indicar el valor del carbono a lo largo del tiempo." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:365 -msgid "price" -msgstr "precio" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:369 -#, fuzzy -msgid "" -"The price of CO2E at the baseline year. Required if Do Valuation is selected " -"and Use Price Table is not selected." -msgstr "" -"El precio del CO2E en el año de referencia. Es necesario si se selecciona la " -"opción de ejecución de valoración y no se selecciona la de utilizar la Tabla " -"de precios." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:374 -msgid "interest rate" -msgstr "tipo de interés" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:377 -msgid "" -"Annual increase in the price of CO2E. Required if Do Valuation is selected and " -"Use Price Table is not selected." -msgstr "" -"Incremento anual del precio del CO2E. Es necesario si se selecciona la opción " -"de hacer valoración y no se selecciona la de utilizar la Tabla de precios." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:382 -msgid "price table" -msgstr "tabla de precios" - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:389 -msgid "Each year from the snapshot year to analysis year." -msgstr "Cada año, desde el año de la instantánea hasta el año de análisis." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:394 -msgid "Price of CO2E in that year." -msgstr "Precio del CO2E en ese año." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:396 -#, fuzzy -msgid "" -"Table of annual CO2E prices for each year from the baseline year to the final " -"snapshot or analysis year. Required if Do Valuation is selected and Use Price " -"Table is selected." -msgstr "" -"Tabla de precios anuales de CO2E para cada año desde el año de referencia " -"hasta la instantánea final o el año de análisis. Se requiere si se selecciona " -"las opciones de ejecutar valoración y usar Tabla de precios." - -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:405 -#, fuzzy -msgid "" -"Annual discount rate on the price of carbon. This is compounded each year " -"after the baseline year. Required if Run Valuation is selected." -msgstr "" -"Tasa de descuento anual sobre el precio del carbono. Se compone cada año " -"después del año de referencia. Se requiere si se selecciona la Valoración de " -"la Ejecución." - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:30 -msgid "LULC lookup table" -msgstr "Tabla de consulta LULC" - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:32 -msgid "" -"A table mapping LULC codes from the snapshot rasters to the corresponding LULC " -"class names, and whether or not the class is a coastal blue carbon habitat." -msgstr "" -"Una tabla que mapea los códigos LULC de los rásters de las instantáneas con " -"los nombres de las clases LULC correspondientes, y si la clase es o no un " -"hábitat costero de carbono azul." - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:39 -msgid "" -"LULC code. Every value in the snapshot LULC maps must have a corresponding " -"entry in this column." -msgstr "" -"Código LULC. Cada valor de los mapas LULC de la instantánea debe tener un " -"input correspondiente en esta columna." - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:45 -msgid "Name of the LULC class." -msgstr "Nombre de la clase LULC." - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:48 -#, fuzzy -msgid "" -"Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if not." -msgstr "" -"Introduzca TRUE si esta clase LULC es un hábitat costero de carbono azul, " -"FALSE si no." - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:59 -msgid "Year to snapshot." -msgstr "Año para la instantánea." - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:63 -msgid "" -"Map of LULC in the snapshot year. All values in this raster must have " -"corresponding entries in the LULC Lookup table." -msgstr "" -"Mapa de LULC en el año de la instantánea. Todos los valores de este ráster " -"deben tener los inputs correspondientes en la tabla LULC Lookup." - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:69 -msgid "A table mapping snapshot years to corresponding LULC maps for each year." -msgstr "" -"Una tabla que relaciona los años de la instantánea con los mapas LULC " -"correspondientes a cada año." - -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:72 -msgid "LULC snapshots table" -msgstr "Tabla de instantáneas LULC" - -#: src/natcap/invest/delineateit/delineateit.py:46 -msgid "" -"Detect pour points (watershed outlets) based on the DEM, and use these instead " -"of a user-provided outlet features vector." -msgstr "" -"Detectar los puntos de vertido (salidas de la cuenca) basándose en el MDE, y " -"utilizarlos en lugar de un vector de características de salida proporcionado " -"por la persona usuaria." - -#: src/natcap/invest/delineateit/delineateit.py:50 -msgid "detect pour points" -msgstr "detección de puntos de vertido" - -#: src/natcap/invest/delineateit/delineateit.py:57 -#, fuzzy -msgid "" -"A map of watershed outlets from which to delineate the watersheds. Required if " -"Detect Pour Points is not checked." -msgstr "" -"Un mapa de puntos de vertido a partir del cual delinear las cuencas " -"hidrográficas. Se requiere si no se marca la opción Detectar puntos de vertido." - -#: src/natcap/invest/delineateit/delineateit.py:60 -msgid "watershed outlets" -msgstr "puntos de salida de la cuenca" - -#: src/natcap/invest/delineateit/delineateit.py:65 -#, fuzzy -msgid "" -"Whether to snap point geometries to the nearest stream pixel. If ``True``, " -"``args['flow_threshold']`` and ``args['snap_distance']`` must also be defined. " -"If a point is equally near to more than one stream pixel, it will be snapped " -"to the stream pixel with the highest flow accumulation value. This has no " -"effect if Detect Pour Points is selected." -msgstr "" -"Si se ajustan las geometrías de los puntos al píxel de flujo más cercano. Si " -"es ``Verdadero``, ``args['flow_threshold']`` y ``args['snap_distance']`` " -"también deben ser definidos. Si un punto está igualmente cerca de más de un " -"píxel de la corriente, se ajustará al píxel de la corriente con el mayor valor " -"de acumulación de flujo. Esto no tiene efecto si se selecciona la opción " -"Detectar puntos de vertido." - -#: src/natcap/invest/delineateit/delineateit.py:73 -msgid "snap points to the nearest stream" -msgstr "ajustar puntos a la corriente más cercana" - -#: src/natcap/invest/delineateit/delineateit.py:78 -#, fuzzy -msgid "about Required if Snap Points is selected." -msgstr "sobre Requerido si se selecciona Puntos de ajuste." - -#: src/natcap/invest/delineateit/delineateit.py:87 -#, fuzzy -msgid "" -"Maximum distance to relocate watershed outlet points in order to snap them to " -"a stream. Required if Snap Points is selected." -msgstr "" -"Distancia máxima para reubicar los puntos de salida de la cuenca con el fin de " -"ajustarlos a una corriente. Se requiere si se selecciona Ajustar puntos." - -#: src/natcap/invest/delineateit/delineateit.py:91 -msgid "snap distance" -msgstr "distancia de ajuste" - -#: src/natcap/invest/delineateit/delineateit.py:96 -#, fuzzy -msgid "" -"Skip delineation for any invalid geometries found in the Outlet Features. " -"Otherwise, an invalid geometry will cause the model to crash." -msgstr "" -"Omitir la delineación para cualquier geometría no válida encontrada en las " -"Características de salida. De lo contrario, una geometría no válida hará que " -"el modelo se bloquee." - -#: src/natcap/invest/delineateit/delineateit.py:100 -msgid "skip invalid geometries" -msgstr "omitir geometrías no válidas" - -#: src/natcap/invest/ndr/ndr.py:25 -#, fuzzy -msgid "Either calc_n or calc_p must be True" -msgstr "O bien calc_n o bien calc_p debe ser True" - -#: src/natcap/invest/ndr/ndr.py:47 -msgid "" -"All values in this raster must have corresponding entries in the Biophysical " -"table." -msgstr "" -"Todos los valores de este ráster deben tener sus inputs correspondientes en la " -"Tabla Biofísica." - -#: src/natcap/invest/ndr/ndr.py:57 -msgid "" -"Map of runoff potential, the capacity to transport nutrients downslope. This " -"can be a quickflow index or annual precipitation. Any units are allowed since " -"the values will be normalized by their average." -msgstr "" -"Mapa del potencial de escorrentía, la capacidad de transportar nutrientes " -"pendiente abajo. Puede ser un índice de flujo rápido o una precipitación " -"anual. Se permite cualquier unidad ya que los valores se normalizarán por su " -"promedio." - -#: src/natcap/invest/ndr/ndr.py:62 -msgid "nutrient runoff proxy" -msgstr "proxy de escorrentía de nutrientes" - -#: src/natcap/invest/ndr/ndr.py:69 -msgid "" -"Map of the boundaries of the watershed(s) over which to aggregate the model " -"results." -msgstr "" -"Mapa de los límites de la(s) cuenca(s) sobre la(s) cual(es) se agregan los " -"resultados del modelo." - -#: src/natcap/invest/ndr/ndr.py:79 -msgid "LULC code for this class corresponding to values in the LULC raster." -msgstr "" -"Código LULC para esta clase correspondiente a los valores del ráster LULC." - -#: src/natcap/invest/ndr/ndr.py:86 -msgid "The nutrient loading for this land use class." -msgstr "La carga de nutrientes para esta clase de uso del suelo." - -#: src/natcap/invest/ndr/ndr.py:90 -msgid "" -"Maximum nutrient retention efficiency. This is the maximum proportion of the " -"nutrient that is retained on this LULC class." -msgstr "" -"Eficiencia máxima de retención de nutrientes. Es la proporción máxima del " -"nutriente que se retiene en esta clase de LULC." - -#: src/natcap/invest/ndr/ndr.py:97 -#, fuzzy -msgid "" -"The distance after which it is assumed that this LULC type retains the " -"nutrient at its maximum capacity. If nutrients travel a shorter distance that " -"this, the retention efficiency will be less than the maximum value eff_x, " -"following an exponential decay." -msgstr "" -"La distancia tras la cual se supone que este tipo de LULC retiene el nutriente " -"a su máxima capacidad. Si los nutrientes recorren una distancia menor que " -"esta, la eficiencia de retención será menor que el valor máximo eff_x, " -"siguiendo un decaimiento exponencial." - -#: src/natcap/invest/ndr/ndr.py:107 -msgid "" -"The proportion of the total amount of nitrogen that are dissolved into the " -"subsurface. By default, this value should be set to 0, indicating that all " -"nutrients are delivered via surface flow. There is no equivalent of this for " -"phosphorus." -msgstr "" -"La proporción de la cantidad total de nitrógeno que se disuelve en el " -"subsuelo. Por defecto, este valor debe fijarse en 0, lo que indica que todos " -"los nutrientes se suministran a través del flujo superficial. No existe un " -"equivalente de esto para el fósforo." - -#: src/natcap/invest/ndr/ndr.py:114 -msgid "" -"A table mapping each LULC class to its biophysical properties related to " -"nutrient load and retention. Replace '[NUTRIENT]' in the column names with 'n' " -"or 'p' for nitrogen or phosphorus respectively. Nitrogen data must be provided " -"if Calculate Nitrogen is selected. Phosphorus data must be provided if " -"Calculate Phosphorus is selected. All LULC codes in the LULC raster must have " -"corresponding entries in this table." -msgstr "" -"Una tabla que asigna cada clase de LULC a sus propiedades biofísicas " -"relacionadas con la carga y la retención de nutrientes. Sustituya " -"\"[NUTRIENTE]\" en los nombres de las columnas por \"n\" o \"p\" para el " -"nitrógeno o el fósforo, respectivamente. Los datos de nitrógeno deben " -"proporcionarse si se selecciona Calcular nitrógeno. Los datos de fósforo deben " -"proporcionarse si se selecciona Calcular fósforo. Todos los códigos LULC en el " -"ráster LULC deben tener los inputs correspondientes en esta tabla." - -#: src/natcap/invest/ndr/ndr.py:127 -msgid "Calculate phosphorus retention and export." -msgstr "Calcular la retención y la exportación de fósforo." - -#: src/natcap/invest/ndr/ndr.py:128 -msgid "calculate phosphorus" -msgstr "calcular el fósforo" - -#: src/natcap/invest/ndr/ndr.py:132 -msgid "Calculate nitrogen retention and export." -msgstr "Calcular la retención y la exportación de nitrógeno." - -#: src/natcap/invest/ndr/ndr.py:133 -msgid "calculate nitrogen" -msgstr "calcular el nitrógeno" - -#: src/natcap/invest/ndr/ndr.py:141 -msgid "" -"Calibration parameter that determines the shape of the relationship between " -"hydrologic connectivity (the degree of connection from patches of land to the " -"stream) and the nutrient delivery ratio (percentage of nutrient that actually " -"reaches the stream)." -msgstr "" -"Parámetro de calibración que determina la forma de la relación entre la " -"conectividad hidrológica (el grado de conexión de los parches de tierra con la " -"corriente) y la proporción de suministro de nutrientes (porcentaje de " -"nutrientes que realmente llegan a la corriente)." - -#: src/natcap/invest/ndr/ndr.py:147 src/natcap/invest/sdr/sdr.py:118 -msgid "Borselli k parameter" -msgstr "Parámetro k de Borselli" - -#: src/natcap/invest/ndr/ndr.py:153 -msgid "subsurface critical length (nitrogen)" -msgstr "longitud crítica en el subsuelo (nitrógeno)" - -#: src/natcap/invest/ndr/ndr.py:154 -#, fuzzy -msgid "" -"The distance traveled (subsurface and downslope) after which it is assumed " -"that soil retains nitrogen at its maximum capacity. Required if Calculate " -"Nitrogen is selected." -msgstr "" -"La distancia recorrida (subsuperficie y pendiente abajo) después de la cual se " -"supone que el suelo retiene el nitrógeno a su máxima capacidad. Se requiere si " -"se selecciona Calcular nitrógeno." - -#: src/natcap/invest/ndr/ndr.py:162 -msgid "subsurface maximum retention efficiency (nitrogen)" -msgstr "eficiencia máxima de retención subsuperficial (nitrógeno)" - -#: src/natcap/invest/ndr/ndr.py:163 -#, fuzzy -msgid "" -"The maximum nitrogen retention efficiency that can be reached through " -"subsurface flow. This characterizes the retention due to biochemical " -"degradation in soils. Required if Calculate Nitrogen is selected." -msgstr "" -"La máxima eficiencia de retención de nitrógeno que se puede alcanzar a través " -"del flujo subsuperficial. Caracteriza la retención debida a la degradación " -"bioquímica en los suelos. Se requiere si se selecciona Calcular Nitrógeno." - -#: src/natcap/invest/recreation/recmodel_client.py:52 -msgid "A unique identifier for the predictor (10 characters or less)." -msgstr "Un identificador único para el predictor (10 caracteres o menos)." - -#: src/natcap/invest/recreation/recmodel_client.py:57 -msgid "A spatial file to use as a predictor." -msgstr "Un archivo espacial para usar como predictor." - -#: src/natcap/invest/recreation/recmodel_client.py:64 -#, fuzzy -msgid "The type of predictor file provided in the 'path' column." -msgstr "El tipo de archivo predictor proporcionado en la columna \"path\"." - -#: src/natcap/invest/recreation/recmodel_client.py:67 -#, fuzzy -msgid "" -"Predictor is a raster. Metric is the mean of values within the AOI grid cell " -"or polygon." -msgstr "" -"El predictor es un ráster. La métrica es la media de los valores dentro de la " -"celda o polígono de la cuadrícula del ADI." - -#: src/natcap/invest/recreation/recmodel_client.py:71 -#, fuzzy -msgid "" -"Predictor is a raster. Metric is the sum of values within the AOI grid cell or " -"polygon." -msgstr "" -"El predictor es un ráster. La métrica es la suma de los valores dentro de la " -"celda de la cuadrícula del ADI o del polígono." - -#: src/natcap/invest/recreation/recmodel_client.py:75 -#, fuzzy -msgid "" -"Predictor is a point vector. Metric is the number of points within each AOI " -"grid cell or polygon." -msgstr "" -"El predictor es un vector de puntos. La métrica es el número de puntos dentro " -"de cada celda de la cuadrícula o polígono del ADI." - -#: src/natcap/invest/recreation/recmodel_client.py:79 -#, fuzzy -msgid "" -"Predictor is a point vector. Metric is the Euclidean distance between the " -"center of each AOI grid cell and the nearest point in this layer." -msgstr "" -"El predictor es un vector de puntos. La métrica es la distancia euclidiana " -"entre el centro de cada celda de la cuadrícula ADI y el punto más cercano de " -"esta capa." - -#: src/natcap/invest/recreation/recmodel_client.py:84 -#, fuzzy -msgid "" -"Predictor is a line vector. Metric is the total length of the lines that fall " -"within each AOI grid cell." -msgstr "" -"El predictor es un vector de líneas. La métrica es la longitud total de las " -"líneas que caen dentro de cada celda de la cuadrícula ADI." - -#: src/natcap/invest/recreation/recmodel_client.py:88 -#, fuzzy -msgid "" -"Predictor is a polygon vector. Metric is the area of overlap between the " -"polygon and each AOI grid cell." -msgstr "" -"El predictor es un vector de polígonos. La métrica es el área de solapamiento " -"entre el polígono y cada celda de la cuadrícula ADI." - -#: src/natcap/invest/recreation/recmodel_client.py:92 -#, fuzzy -msgid "" -"Predictor is a polygon vector. Metric is the percentage (0-100) of overlapping " -"area between the polygon and each AOI grid cell." -msgstr "" -"El predictor es un vector de polígonos. La métrica es el porcentaje (0-100) " -"del área de superposición entre el polígono y cada celda de la cuadrícula ADI." - -#: src/natcap/invest/recreation/recmodel_client.py:111 -msgid "Map of area(s) over which to run the model." -msgstr "Mapa de la(s) zona(s) sobre la(s) que se va a ejecutar el modelo." - -#: src/natcap/invest/recreation/recmodel_client.py:116 -msgid "FQDN to a recreation server. If not provided, a default is assumed." -msgstr "" -"FQDN a un servidor de recreación. Si no se proporciona, se asume un valor por " -"defecto." - -#: src/natcap/invest/recreation/recmodel_client.py:119 -#, fuzzy -msgid "hostname" -msgstr "nombre de host" - -#: src/natcap/invest/recreation/recmodel_client.py:126 -#, fuzzy -msgid "the port on ``hostname`` to use for contacting the recreation server." -msgstr "" -"el puerto en ``hostname`` a utilizar para contactar con el servidor de " -"recreación." - -#: src/natcap/invest/recreation/recmodel_client.py:129 -msgid "port" -msgstr "puerto" - -#: src/natcap/invest/recreation/recmodel_client.py:135 -msgid "" -"Year at which to start photo user-day calculations. Calculations start on the " -"first day of the year. Year must be in the range 2005 - 2017, and must be less " -"than or equal to the End Year." -msgstr "" -"Año en el que se inician los cálculos de los días de usuario de las fotos. Los " -"cálculos comienzan el primer día del año. El año debe estar en el rango 2005 - " -"2017, y debe ser menor o igual que el año final." - -#: src/natcap/invest/recreation/recmodel_client.py:140 -msgid "start year" -msgstr "año de inicio" - -#: src/natcap/invest/recreation/recmodel_client.py:146 -msgid "" -"Year at which to end photo user-day calculations. Calculations continue " -"through the last day of the year. Year must be in the range 2005 - 2017, and " -"must be greater than or equal to the Start Year." -msgstr "" -"Año en el que se terminan los cálculos de los días de uso de las fotos. Los " -"cálculos continúan hasta el último día del año. El año debe estar en el rango " -"2005 - 2017, y debe ser mayor o igual que el año de inicio." - -#: src/natcap/invest/recreation/recmodel_client.py:151 -msgid "end year" -msgstr "año final" - -#: src/natcap/invest/recreation/recmodel_client.py:156 -#, fuzzy -msgid "" -"Divide the AOI polygons into equal-sized grid cells, and compute results for " -"those cells instead of the original polygons." -msgstr "" -"Divida los polígonos del ADI en celdas de cuadrícula de igual tamaño y calcule " -"los resultados para esas celdas en lugar de los polígonos originales." - -# Check English -#: src/natcap/invest/recreation/recmodel_client.py:160 -#, fuzzy -msgid "grid the AOI" -msgstr "cuadrícula de la AOI" - -#: src/natcap/invest/recreation/recmodel_client.py:165 -msgid "square" -msgstr "cuadrado" - -#: src/natcap/invest/recreation/recmodel_client.py:166 -msgid "hexagon" -msgstr "hexágono" - -#: src/natcap/invest/recreation/recmodel_client.py:169 -#, fuzzy -msgid "" -"The shape of grid cells to make within the AOI polygons. Required if Grid AOI " -"is selected." -msgstr "" -"La forma de las celdas de la cuadrícula a realizar dentro de los polígonos de " -"la ADI. Se requiere si se selecciona Grilla de ADI ." - -#: src/natcap/invest/recreation/recmodel_client.py:172 -msgid "grid type" -msgstr "tipo de cuadrícula" - -#: src/natcap/invest/recreation/recmodel_client.py:179 -#, fuzzy -msgid "" -"Size of grid cells to make, measured in the projection units of the AOI. If " -"the Grid Type is 'square', this is the length of each side of the square. If " -"the Grid Type is 'hexagon', this is the hexagon's maximal diameter." -msgstr "" -"Tamaño de las celdas de la cuadrícula a realizar, medido en las unidades de " -"proyección del ADI. Si el tipo de cuadrícula es \"cuadrado\", es la longitud " -"de cada lado del cuadrado. Si el tipo de cuadrícula es \"hexágono\", es el " -"diámetro máximo del hexágono." - -#: src/natcap/invest/recreation/recmodel_client.py:184 -msgid "cell size" -msgstr "tamaño de la celda" - -#: src/natcap/invest/recreation/recmodel_client.py:189 -msgid "" -"Run the regression model using the predictor table and scenario table, if " -"provided." -msgstr "" -"Ejecute el modelo de regresión utilizando la tabla de predictores y la tabla " -"de escenarios, si se proporciona." - -#: src/natcap/invest/recreation/recmodel_client.py:192 -msgid "compute regression" -msgstr "calcular la regresión" - -#: src/natcap/invest/recreation/recmodel_client.py:198 -msgid "" -"A table that maps predictor IDs to spatial files and their predictor metric " -"types. The file paths can be absolute or relative to the table." -msgstr "" -"Una tabla que asigna los ID de los predictores a los archivos espaciales y a " -"sus tipos de métricas de predicción. Las rutas de los archivos pueden ser " -"absolutas o relativas a la tabla." - -#: src/natcap/invest/recreation/recmodel_client.py:202 -msgid "predictor table" -msgstr "tabla de predicción" - -#: src/natcap/invest/recreation/recmodel_client.py:208 -msgid "" -"A table of future or alternative scenario predictors. Maps IDs to files and " -"their types. The file paths can be absolute or relative to the table." -msgstr "" -"Una tabla de predictores de escenarios futuros o alternativos. Asigna los ID a " -"los archivos y sus tipos. Las rutas de los archivos pueden ser absolutas o " -"relativas a la tabla." - -#: src/natcap/invest/recreation/recmodel_client.py:212 -msgid "scenario predictor table" -msgstr "tabla de predicción de escenarios" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:68 -msgid "features impacting scenic quality" -msgstr "características que afectan a la calidad del paisaje" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:76 -msgid "" -"Maximum length of the line of sight originating from a viewpoint. The value " -"can either be positive (preferred) or negative (kept for backwards " -"compatibility), but is converted to a positive number. If this field is not " -"provided, the model will include all pixels in the DEM in the visibility " -"analysis. RADIUS preferred, but may also be called RADIUS2 for backwards " -"compatibility." -msgstr "" -"Longitud máxima de la línea de visión originada por un punto de vista. El " -"valor puede ser positivo (preferido) o negativo (se mantiene por " -"compatibilidad con versiones anteriores), pero se convierte en un número " -"positivo. Si no se proporciona este campo, el modelo incluirá todos los " -"píxeles del MDE en el análisis de visibilidad. Se prefiere RADIUS, pero " -"también puede llamarse RADIUS2 por compatibilidad con versiones anteriores." - -# Not sure how to translate viewshed -#: src/natcap/invest/scenic_quality/scenic_quality.py:89 -#, fuzzy -msgid "" -"Viewshed importance coefficient. If this field is provided, the values are " -"used to weight each feature's viewshed impacts. If not provided, all viewsheds " -"are equally weighted with a weight of 1." -msgstr "" -"Coeficiente de importancia de la vista. Si se proporciona este campo, los " -"valores se utilizan para ponderar los impactos de las vistas de cada " -"característica. Si no se proporciona, todas las vistas se ponderan por igual " -"con un peso de 1." - -#: src/natcap/invest/scenic_quality/scenic_quality.py:98 -msgid "" -"Viewpoint height, the elevation above the ground of each feature. If this " -"field is not provided, defaults to 0." -msgstr "" -"Altura del punto de vista, la elevación sobre el suelo de cada característica. " -"Si no se proporciona este campo, el valor predeterminado es 0." - -#: src/natcap/invest/scenic_quality/scenic_quality.py:103 -msgid "" -"Map of locations of objects that negatively affect scenic quality. This must " -"have the same projection as the DEM." -msgstr "" -"Mapa de ubicación de los objetos que afectan negativamente a la calidad del " -"paisaje. Debe tener la misma proyección que el MDE." - -#: src/natcap/invest/scenic_quality/scenic_quality.py:113 -msgid "refractivity coefficient" -msgstr "coeficiente de refractividad" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:115 -msgid "" -"The refractivity coefficient corrects for the curvature of the earth and " -"refraction of visible light in air." -msgstr "" -"El coeficiente de refracción corrige la curvatura de la tierra y la refracción " -"de la luz visible en el aire." - -#: src/natcap/invest/scenic_quality/scenic_quality.py:126 -msgid "Valuation function" -msgstr "Función de valoración" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:130 -msgid "linear: a + bx" -msgstr "lineal: a + bx" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:131 -msgid "logarithmic: a + b log(x+1)" -msgstr "logarítmico: a + b log(x+1)" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:133 -msgid "exponential: a * e^(-bx)" -msgstr "exponencial: a * e^(-bx)" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:135 -msgid "" -"Valuation function used to calculate the visual impact of each feature, given " -"distance from the feature 'x' and parameters 'a' and 'b'." -msgstr "" -"Función de valoración utilizada para calcular el impacto visual de cada " -"característica, dada la distancia de la característica \"x\" y los parámetros " -"\"a\" y \"b\"." - -#: src/natcap/invest/scenic_quality/scenic_quality.py:141 -msgid "coefficient a" -msgstr "coeficiente a" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:145 -msgid "First coefficient ('a') used by the valuation function" -msgstr "Primer coeficiente ('a') utilizado por la función de valoración" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:148 -msgid "coefficient b" -msgstr "coeficiente b" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:152 -msgid "Second coefficient ('b') used by the valuation function" -msgstr "Segundo coeficiente ('b') utilizado por la función de valoración" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:155 -msgid "maximum valuation radius" -msgstr "radio máximo de valoración" - -#: src/natcap/invest/scenic_quality/scenic_quality.py:160 -msgid "" -"Valuation will only be computed for cells that fall within this radius of a " -"feature impacting scenic quality." -msgstr "" -"La valoración solo se calculará para las celdas que se encuentren dentro de " -"este radio de un elemento que afecte a la calidad del paisaje." - -#: src/natcap/invest/sdr/sdr.py:30 -#, fuzzy -msgid "{number} features have a non-integer ws_id field" -msgstr "{number} las características tienen un campo ws_id no entero" - -#: src/natcap/invest/sdr/sdr.py:55 -msgid "" -"Map of rainfall erosivity, reflecting the intensity and duration of rainfall " -"in the area of interest." -msgstr "" -"Mapa de erosividad pluvial, que refleja la intensidad y duración de las " -"lluvias en la zona de interés." - -#: src/natcap/invest/sdr/sdr.py:58 -msgid "erosivity" -msgstr "erosividad" - -#: src/natcap/invest/sdr/sdr.py:66 -msgid "" -"Map of soil erodibility, the susceptibility of soil particles to detachment " -"and transport by rainfall and runoff." -msgstr "" -"Mapa de erodabilidad del suelo, la susceptibilidad de las partículas del suelo " -"al desprendimiento y al transporte por la lluvia y la escorrentía." - -#: src/natcap/invest/sdr/sdr.py:70 -msgid "soil erodibility" -msgstr "erosionabilidad del suelo" - -#: src/natcap/invest/sdr/sdr.py:84 -msgid "Unique identifier for the watershed." -msgstr "Identificador único de la cuenca hidrográfica." - -#: src/natcap/invest/sdr/sdr.py:88 -msgid "" -"Map of the boundaries of the watershed(s) over which to aggregate results. " -"Each watershed should contribute to a point of interest where water quality " -"will be analyzed." -msgstr "" -"Mapa de los límites de la(s) cuenca(s) sobre la(s) que se van a agregar los " -"resultados. Cada cuenca debe contribuir a un punto de interés en el que se " -"analizará la calidad del agua." - -#: src/natcap/invest/sdr/sdr.py:92 -msgid "Watersheds" -msgstr "Cuencas hidrográficas" - -#: src/natcap/invest/sdr/sdr.py:99 -msgid "LULC code from the LULC raster." -msgstr "Código LULC del ráster LULC." - -#: src/natcap/invest/sdr/sdr.py:102 -msgid "Cover-management factor for the USLE" -msgstr "Factor de gestión de la cubierta para la USLE" - -#: src/natcap/invest/sdr/sdr.py:105 -msgid "Support practice factor for the USLE" -msgstr "Factor de práctica de apoyo para la USLE" - -#: src/natcap/invest/sdr/sdr.py:107 -msgid "" -"A table mapping each LULC code to biophysical properties of that LULC class. " -"All values in the LULC raster must have corresponding entries in this table." -msgstr "" -"Una tabla que asigna cada código LULC a las propiedades biofísicas de esa " -"clase LULC. Todos los valores de la trama LULC deben tener los inputs " -"correspondientes en esta tabla." - -#: src/natcap/invest/sdr/sdr.py:117 -msgid "Borselli k parameter." -msgstr "Parámetro k de Borselli." - -#: src/natcap/invest/sdr/sdr.py:122 -msgid "The maximum SDR value that a pixel can have." -msgstr "El valor máximo de SDR que puede tener un píxel." - -#: src/natcap/invest/sdr/sdr.py:123 -msgid "maximum SDR value" -msgstr "valor máximo de SDR" - -#: src/natcap/invest/sdr/sdr.py:128 -msgid "Borselli IC0 parameter." -msgstr "Parámetro Borselli IC0." - -#: src/natcap/invest/sdr/sdr.py:129 -msgid "Borselli IC0 parameter" -msgstr "Parámetro Borselli IC0" - -#: src/natcap/invest/sdr/sdr.py:135 -msgid "" -"The maximum allowed value of the slope length parameter (L) in the LS factor." -msgstr "" -"El valor máximo permitido del parámetro de longitud de la pendiente (L) en el " -"factor LS." - -#: src/natcap/invest/sdr/sdr.py:138 -msgid "maximum l value" -msgstr "valor máximo de l" - -#: src/natcap/invest/sdr/sdr.py:144 -msgid "" -"Map of locations of artificial drainages that drain to the watershed. Pixels " -"with 1 are drainages and are treated like streams. Pixels with 0 are not " -"drainages." -msgstr "" -"Mapa de las ubicaciones de los drenajes artificiales que drenan a la cuenca. " -"Los píxeles con 1 son drenajes y se tratan como corrientes. Los píxeles con 0 " -"no son drenajes." - -#: src/natcap/invest/sdr/sdr.py:148 -msgid "drainages" -msgstr "drenajes" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:55 -msgid "" -"Twelve files, one for each month. File names must end with the month number " -"(1-12). For example, the filenames 'et0_1.tif' 'evapotranspiration1.tif' are " -"both valid for the month of January." -msgstr "" -"Doce archivos, uno por cada mes. Los nombres de los archivos deben terminar " -"con el número del mes (1-12). Por ejemplo, los nombres de archivo \"et0_1.tif" -"\" \"evapotranspiración1.tif\" son válidos para el mes de enero." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:64 -msgid "" -"Directory containing maps of reference evapotranspiration for each month. " -"Only .tif files should be in this folder (no .tfw, .xml, etc files)." -msgstr "" -"Directorio que contiene los mapas de evapotranspiración de referencia para " -"cada mes. En esta carpeta solo debe haber archivos .tif (no hay archivos ." -"tfw, .xml, etc.)." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:68 -msgid "ET0 directory" -msgstr "Directorio ET0" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:76 -msgid "" -"Twelve files, one for each month. File names must end with the month number " -"(1-12). For example, the filenames 'precip_1.tif' and 'precip1.tif' are both " -"valid names for the month of January." -msgstr "" -"Doce archivos, uno por cada mes. Los nombres de los archivos deben terminar " -"con el número del mes (1-12). Por ejemplo, los nombres de archivo 'precip_1." -"tif' y 'precip1.tif' son ambos válidos para el mes de enero." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:84 -msgid "" -"Directory containing maps of monthly precipitation for each month. Only .tif " -"files should be in this folder (no .tfw, .xml, etc files)." -msgstr "" -"Directorio que contiene los mapas de precipitación mensual para cada mes. En " -"esta carpeta solo debe haber archivos .tif (no hay archivos .tfw, .xml, etc.)." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:88 -msgid "precipitation directory" -msgstr "directorio de precipitación" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:97 -msgid "" -"All values in this raster MUST have corresponding entries in the Biophysical " -"Table." -msgstr "" -"Todos los valores de este ráster deben tener sus correspondientes inputs en la " -"Tabla Biofísica." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:115 -msgid "LULC code matching those in the LULC raster." -msgstr "Código LULC que coincide con los del ráster LULC." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:119 -msgid "" -"Curve number values for each combination of soil group and LULC class. Replace " -"[SOIL_GROUP] with each soil group code A, B, C, D so that there is one column " -"for each soil group. Curve number values must be greater than 0." -msgstr "" -"Valores del número de la curva para cada combinación de grupo de suelos y " -"clase LULC. Sustituya [GRUPO_SUELO] por el código de cada grupo de suelo A, B, " -"C, D para que haya una columna para cada grupo de suelo. Los valores del " -"número de la curva deben ser mayores que 0." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:129 -msgid "" -"Crop/vegetation coefficient (Kc) values for this LULC class in each month. " -"Replace [MONTH] with the numbers 1 to 12 so that there is one column for each " -"month." -msgstr "" -"Valores del coeficiente de cultivo/vegetación (Kc) para esta clase LULC en " -"cada mes. Sustituya [MES] por los números del 1 al 12 para que haya una " -"columna para cada mes." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:136 -msgid "" -"A table mapping each LULC code to biophysical properties of the corresponding " -"LULC class. All values in the LULC raster must have corresponding entries in " -"this table." -msgstr "" -"Una tabla que asigna cada código LULC a las propiedades biofísicas de la clase " -"LULC correspondiente. Todos los valores de la trama LULC deben tener los " -"inputs correspondientes en esta tabla." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:148 -msgid "" -"Values are the numbers 1-12 corresponding to each month, January (1) through " -"December (12)." -msgstr "" -"Los valores son los números del 1 al 12 correspondientes a cada mes, de enero " -"(1) a diciembre (12)." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:155 -msgid "The number of rain events in that month." -msgstr "El número de eventos de lluvia en ese mes." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:161 -#, fuzzy -msgid "" -"A table containing the number of rain events for each month. Required if " -"neither User-Defined Local Recharge nor User-Defined Climate Zones is selected." -msgstr "" -"Una tabla que contiene el número de eventos de lluvia para cada mes. Se " -"requiere si no se selecciona ni Recarga Local Definida por el Usuario ni Zonas " -"Climáticas Definidas por el Usuario." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:165 -msgid "rain events table" -msgstr "tabla de eventos de lluvia" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:170 -msgid "" -"The proportion of upslope annual available local recharge that is available in " -"each month. Required if Use Monthly Alpha Table is not selected." -msgstr "" -"La proporción de la recarga local anual disponible pendiente arriba que está " -"disponible en cada mes. Requerido si no se selecciona la opción de usar la " -"tabla mensual Alpha." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:174 -msgid "alpha_m parameter" -msgstr "parámetro alpha_m" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:178 -msgid "" -"The proportion of the upgradient subsidy that is available for downgradient " -"evapotranspiration." -msgstr "" -"La proporción del subsidio ascendente que está disponible para la " -"evapotranspiración descendente." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:181 -msgid "beta_i parameter" -msgstr "parámetro beta_i" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:185 -msgid "" -"The proportion of pixel local recharge that is available to downgradient " -"pixels." -msgstr "" -"La proporción de la recarga local del píxel que está disponible para los " -"píxeles pendiente abajo." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:188 -msgid "gamma parameter" -msgstr "parámetro gamma" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:192 -msgid "" -"Use user-defined local recharge data instead of calculating local recharge " -"from the other provided data." -msgstr "" -"Utilizar los datos de recarga local definidos por quien usa el modelo en lugar " -"de calcular la recarga local a partir de los otros datos proporcionados." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:195 -msgid "user-defined recharge layer (advanced)" -msgstr "capa de recarga definida por quien usa el modelo (avanzado)" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:205 -msgid "" -"Map of local recharge data. Required if User-Defined Local Recharge is " -"selected." -msgstr "" -"Mapa de datos de recarga local. Se necesita si se selecciona la opción de " -"recarga local definida por quien usa el modelo." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:208 -msgid "local recharge" -msgstr "recarga local" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:212 -msgid "Use user-defined climate zone data in lieu of a global rain events table." -msgstr "" -"Utilizar datos de zonas climáticas definidas por quien usa el modelo en lugar " -"de una tabla global de eventos de lluvia." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:215 -msgid "climate zones (advanced)" -msgstr "zonas climáticas (avanzado)" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:222 -msgid "" -"Climate zone ID numbers, corresponding to the values in the Climate Zones map." -msgstr "" -"Números de identificación de la zona climática, correspondientes a los valores " -"del mapa de las zonas climáticas." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:228 -msgid "" -"The number of rain events that occur in each month in this climate zone. " -"Replace [MONTH] with the month abbreviations: jan, feb, mar, apr, may, jun, " -"jul, aug, sep, oct, nov, dec, so that there is a column for each month." -msgstr "" -"El número de eventos de lluvia que se producen en cada mes en esta zona " -"climática. Sustituya [MES] por las abreviaturas de los meses: ene, feb, mar, " -"abr, may, jun, jul, ago, sep, oct, nov y dic, de modo que haya una columna " -"para cada mes." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:236 -#, fuzzy -msgid "" -"Table of monthly precipitation events for each climate zone. Required if User-" -"Defined Climate Zones is selected." -msgstr "" -"Tabla de eventos de precipitación mensual para cada zona climática. Se " -"requiere si se selecciona Zonas Climáticas Definidas por el Usuario." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:239 -msgid "climate zone table" -msgstr "tabla de zonas climáticas" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:246 -msgid "" -"Map of climate zones. All values in this raster must have corresponding " -"entries in the Climate Zone Table." -msgstr "" -"Mapa de zonas climáticas. Todos los valores de este raster deben tener los " -"inputs correspondientes en la Tabla de Zonas Climáticas." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:249 -msgid "climate zone map" -msgstr "mapa de zonas climáticas" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:253 -msgid "Use montly alpha values instead of a single value for the whole year." -msgstr "" -"Utilizar valores alfa mensuales en lugar de un único valor para todo el año." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:256 -msgid "use monthly alpha table (advanced)" -msgstr "utilizar la tabla alfa mensual (avanzado)" - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:264 -msgid "Values are the numbers 1-12 corresponding to each month." -msgstr "Los valores son los números 1-12 correspondientes a cada mes." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:271 -msgid "The alpha value for that month." -msgstr "El valor alfa de ese mes." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:275 -#, fuzzy -msgid "" -"Table of alpha values for each month. Required if Use Monthly Alpha Table is " -"selected." -msgstr "" -"Tabla de valores alfa para cada mes. Es necesaria si se selecciona Usar tabla " -"de alfa mensual." - -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:278 -msgid "monthly alpha table" -msgstr "tabla alfa mensual" +# Spanish translations for InVEST. +# Copyright (C) 2022 Natural Capital Project +# This file is distributed under the same license as the InVEST project. +# FIRST AUTHOR , 2022. +# +msgid "" +msgstr "" +"Project-Id-Version: InVEST 3.12\n" +"Report-Msgid-Bugs-To: natcap-software@lists.stanford.edu\n" +"POT-Creation-Date: 2024-03-25 13:25-0700\n" +"PO-Revision-Date: 2022-11-19 17:42-0500\n" +"Last-Translator: Patricio Mena pamv59@gmail.com\n" +"Language: es\n" +"Language-Team: es \n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=utf-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Generated-By: Babel 2.14.0\n" + +#: src/natcap/invest/annual_water_yield.py:92 +#: src/natcap/invest/annual_water_yield.py:186 +msgid "Unique identifier for each subwatershed." +msgstr "Identificador único para cada subcuenca." + +#: src/natcap/invest/annual_water_yield.py:101 +#: src/natcap/invest/annual_water_yield.py:170 +msgid "Unique identifier for each watershed." +msgstr "Identificador único para cada cuenca hidrográfica." + +#: src/natcap/invest/annual_water_yield.py:129 +#: src/natcap/invest/forest_carbon_edge_effect.py:115 +#: src/natcap/invest/sdr/sdr.py:74 +msgid "" +"All values in this raster must have corresponding entries in the " +"Biophysical Table." +msgstr "" +"Todos los valores de este ráster deben tener sus correspondientes inputs" +" en la Tabla Biofísica." + +#: src/natcap/invest/annual_water_yield.py:140 +msgid "" +"Map of root restricting layer depth, the soil depth at which root " +"penetration is strongly inhibited because of physical or chemical " +"characteristics." +msgstr "" +"Mapa de la profundidad de la capa restrictiva de las raíces, la " +"profundidad del suelo a la que la penetración de las raíces está " +"fuertemente inhibida debido a las características físicas o químicas." + +#: src/natcap/invest/annual_water_yield.py:144 +msgid "root restricting layer depth" +msgstr "profundidad de la capa que restringe las raíces" + +#: src/natcap/invest/annual_water_yield.py:154 +msgid "" +"Map of plant available water content, the fraction of water that can be " +"stored in the soil profile that is available to plants." +msgstr "" +"Mapa del contenido de agua disponible para las plantas, la fracción de " +"agua que puede almacenarse en el perfil del suelo y que está disponible " +"para las plantas." + +#: src/natcap/invest/annual_water_yield.py:158 +msgid "plant available water content" +msgstr "contenido de agua disponible de la planta" + +#: src/natcap/invest/annual_water_yield.py:174 +msgid "" +"Map of watershed boundaries, such that each watershed drains to a point " +"of interest where hydropower production will be analyzed." +msgstr "" +"Mapa de los límites de las cuencas hidrográficas, de forma que cada " +"cuenca drene a un punto de interés en el que se analizará la producción " +"hidroeléctrica." + +#: src/natcap/invest/annual_water_yield.py:178 src/natcap/invest/ndr/ndr.py:73 +msgid "watersheds" +msgstr "cuencas hidrográficas" + +#: src/natcap/invest/annual_water_yield.py:191 +msgid "" +"Map of subwatershed boundaries within each watershed in the Watersheds " +"map." +msgstr "" +"Mapa de los límites de las subcuencas dentro de cada cuenca hidrográfica " +"en el mapa de cuencas." + +#: src/natcap/invest/annual_water_yield.py:194 +msgid "sub-watersheds" +msgstr "subcuencas" + +#: src/natcap/invest/annual_water_yield.py:202 +msgid "" +"Code indicating whether the the LULC class is vegetated for the purpose " +"of AET. Enter 1 for all vegetated classes except wetlands, and 0 for all " +"other classes, including wetlands, urban areas, water bodies, etc." +msgstr "" +"Código que indica si la clase LULC tiene vegetación a efectos de la ETR. " +"Introduzca 1 para todas las clases con vegetación, excepto los humedales," +" y 0 para todas las demás clases, incluidos los humedales, las zonas " +"urbanas, las masas de agua, etc." + +#: src/natcap/invest/annual_water_yield.py:212 +msgid "" +"Maximum root depth for plants in this LULC class. Only used for classes " +"with a 'lulc_veg' value of 1." +msgstr "" +"Profundidad máxima de las raíces de las plantas de esta clase LULC. Solo " +"se utiliza para las clases con un valor 'lulc_veg' de 1." + +#: src/natcap/invest/annual_water_yield.py:219 +#: src/natcap/invest/urban_cooling_model.py:65 +msgid "Crop coefficient for this LULC class." +msgstr "Coeficiente de cultivo para esta clase de LULC." + +#: src/natcap/invest/annual_water_yield.py:222 +msgid "" +"Table of biophysical parameters for each LULC class. All values in the " +"LULC raster must have corresponding entries in this table." +msgstr "" +"Tabla de parámetros biofísicos para cada clase LULC. Todos los valores " +"del ráster LULC deben tener los inputs correspondientes en esta tabla." + +#: src/natcap/invest/annual_water_yield.py:226 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:208 +#: src/natcap/invest/forest_carbon_edge_effect.py:111 +#: src/natcap/invest/ndr/ndr.py:120 src/natcap/invest/pollination.py:118 +#: src/natcap/invest/sdr/sdr.py:105 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:137 +#: src/natcap/invest/urban_cooling_model.py:57 +#: src/natcap/invest/urban_flood_risk_mitigation.py:77 +msgid "biophysical table" +msgstr "tabla biofísica" + +#: src/natcap/invest/annual_water_yield.py:232 +msgid "" +"The seasonality factor, representing hydrogeological characterisitics and" +" the seasonal distribution of precipitation. Values typically range from " +"1 - 30." +msgstr "" +"El factor de estacionalidad, que representa las características " +"hidrogeológicas y la distribución estacional de las precipitaciones. Los " +"valores oscilan típicamente entre 1 y 30." + +#: src/natcap/invest/annual_water_yield.py:236 +msgid "z parameter" +msgstr "parámetro z" + +#: src/natcap/invest/annual_water_yield.py:242 +msgid "LULC code corresponding to the LULC raster" +msgstr "Código LULC correspondiente al ráster LULC" + +#: src/natcap/invest/annual_water_yield.py:246 +msgid "Average consumptive water use in this LULC class." +msgstr "Uso consuntivo promedio del agua en esta clase de LULC." + +#: src/natcap/invest/annual_water_yield.py:254 +msgid "" +"A table of water demand for each LULC class. Each LULC code in the LULC " +"raster must have a corresponding row in this table." +msgstr "" +"Una tabla de demanda de agua para cada clase LULC. Cada código LULC en el" +" raster LULC debe tener una fila correspondiente en esta tabla." + +#: src/natcap/invest/annual_water_yield.py:258 +msgid "water demand table" +msgstr "tabla de demanda de agua" + +#: src/natcap/invest/annual_water_yield.py:265 +msgid "" +"Unique identifier for the hydropower station. This must match the 'ws_id'" +" value for the corresponding watershed in the Watersheds vector. Each " +"watershed in the Watersheds vector must have its 'ws_id' entered in this " +"column." +msgstr "" +"Identificador único de la central hidroeléctrica. Debe coincidir con el " +"valor \"ws_id\" de la cuenca hidrográfica correspondiente en el vector " +"\"Watersheds\". Cada cuenca hidrográfica del vector Cuencas Hidrográficas" +" debe tener su \"ws_id\" introducido en esta columna." + +#: src/natcap/invest/annual_water_yield.py:274 +msgid "" +"Turbine efficiency, the proportion of potential energy captured and " +"converted to electricity by the turbine." +msgstr "" +"Eficiencia de la turbina, la proporción de energía potencial captada y " +"convertida en electricidad por la turbina." + +#: src/natcap/invest/annual_water_yield.py:281 +msgid "The proportion of inflow water volume that is used to generate energy." +msgstr "" +"La proporción del volumen de agua de entrada que se utiliza para generar " +"energía." + +#: src/natcap/invest/annual_water_yield.py:288 +msgid "" +"The head, measured as the average annual effective height of water behind" +" each dam at the turbine intake." +msgstr "" +"La cabeza, medida como la altura media anual efectiva del agua detrás de " +"cada represa en la toma de la turbina." + +# In these cases I don´t know if I should translate the column names. In +# general I have used the Needs work button in all cases where there is doubt +# about the need to translate certain coded terms. +#: src/natcap/invest/annual_water_yield.py:296 +#, fuzzy +msgid "" +"The price of power produced by the station. Must be in the same currency " +"used in the 'cost' column." +msgstr "" +"El precio de la energía producida por la estación. Debe estar en la misma" +" moneda utilizada en la columna \"costo\"." + +#: src/natcap/invest/annual_water_yield.py:303 +msgid "" +"Annual maintenance and operations cost of running the hydropower station." +" Must be in the same currency used in the 'kw_price' column." +msgstr "" +"Costo anual de mantenimiento y explotación de la central hidroeléctrica. " +"Debe estar en la misma moneda utilizada en la columna \"kw_price\"." + +#: src/natcap/invest/annual_water_yield.py:311 +msgid "" +"Number of years over which to value the hydropower station. This is " +"either the station's expected lifespan or the duration of the land use " +"scenario of interest." +msgstr "" +"Número de años a lo largo de los cuales valorar la central " +"hidroeléctrica. Se trata de la vida útil prevista de la central o de la " +"duración del escenario de uso del suelo de interés." + +#: src/natcap/invest/annual_water_yield.py:319 +msgid "The annual discount rate, applied for each year in the time span." +msgstr "La tasa de descuento anual, aplicada para cada año del período." + +#: src/natcap/invest/annual_water_yield.py:326 +msgid "" +"A table mapping each watershed to the associated valuation parameters for" +" its hydropower station." +msgstr "" +"Una tabla que relaciona cada cuenca con los parámetros de valoración " +"asociados a su central hidroeléctrica." + +#: src/natcap/invest/annual_water_yield.py:329 +msgid "hydropower valuation table" +msgstr "tabla de valoración hidroeléctrica" + +#: src/natcap/invest/carbon.py:59 +msgid "" +"A map of LULC for the current scenario. All values in this raster must " +"have corresponding entries in the Carbon Pools table." +msgstr "" +"Un mapa de LULC para el escenario actual. Todos los valores de este " +"ráster deben tener los inputs correspondientes en la tabla de reservas de" +" carbono." + +#: src/natcap/invest/carbon.py:63 +msgid "current LULC" +msgstr "LULC actual" + +#: src/natcap/invest/carbon.py:68 +msgid "" +"Run sequestration analysis. This requires inputs of LULC maps for both " +"current and future scenarios. Required if REDD scenario analysis or run " +"valuation model is selected." +msgstr "" +"Ejecutar el análisis de secuestración. Esto requiere la introducción de " +"mapas LULC para los escenarios actuales y futuros. Es necesario si se " +"selecciona el análisis del escenario REDD o la ejecución del modelo de " +"valoración." + +#: src/natcap/invest/carbon.py:73 +msgid "calculate sequestration" +msgstr "calcular la secuestración" + +#: src/natcap/invest/carbon.py:80 +#, fuzzy +msgid "" +"A map of LULC for the future scenario. If run valuation model is " +"selected, this should be the reference, or baseline, future scenario " +"against which to compare the REDD policy scenario. All values in this " +"raster must have corresponding entries in the Carbon Pools table. " +"Required if Calculate Sequestration is selected." +msgstr "" +"Un mapa de LULC para el escenario futuro. Si se selecciona el modelo de " +"ejecución de valoración, este debe ser el escenario futuro de referencia," +" o línea de base, con el que se comparará el escenario de la política " +"REDD. Todos los valores de este ráster deben tener los inputs " +"correspondientes en la tabla de reservas de carbono. Es necesario si se " +"selecciona la opción de calcular secuestración." + +#: src/natcap/invest/carbon.py:88 +msgid "future LULC" +msgstr "LULC futuro" + +#: src/natcap/invest/carbon.py:93 +msgid "" +"Run REDD scenario analysis. This requires three LULC maps: one for the " +"current scenario, one for the future baseline scenario, and one for the " +"future REDD policy scenario." +msgstr "" +"Ejecutar el análisis del escenario REDD. Esto requiere tres mapas LULC: " +"uno para el escenario actual, otro para el escenario de referencia futuro" +" y otro para el escenario de la futura política REDD." + +#: src/natcap/invest/carbon.py:98 +msgid "REDD scenario analysis" +msgstr "Análisis del escenario REDD" + +#: src/natcap/invest/carbon.py:105 +#, fuzzy +msgid "" +"A map of LULC for the REDD policy scenario. All values in this raster " +"must have corresponding entries in the Carbon Pools table. Required if " +"REDD Scenario Analysis is selected." +msgstr "" +"Un mapa de LULC para el escenario de la política REDD. Todos los valores " +"de este ráster deben tener los inputs correspondientes en la tabla de " +"reservas de carbono. En necesario si se selecciona el análisis del " +"escenario REDD." + +#: src/natcap/invest/carbon.py:110 +msgid "REDD LULC" +msgstr "LULC de REDD" + +#: src/natcap/invest/carbon.py:119 +msgid "Carbon density of aboveground biomass." +msgstr "Densidad de carbono de la biomasa aérea." + +#: src/natcap/invest/carbon.py:123 +msgid "Carbon density of belowground biomass." +msgstr "Densidad de carbono de la biomasa subterránea." + +#: src/natcap/invest/carbon.py:127 +msgid "Carbon density of soil." +msgstr "Densidad de carbono del suelo." + +#: src/natcap/invest/carbon.py:131 +msgid "Carbon density of dead matter." +msgstr "Densidad de carbono de la materia muerta." + +#: src/natcap/invest/carbon.py:134 +msgid "A table that maps each LULC code to carbon pool data for that LULC type." +msgstr "" +"Una tabla que mapea cada código LULC con los datos de la reserva de " +"carbono para ese tipo LULC." + +#: src/natcap/invest/carbon.py:137 +msgid "carbon pools" +msgstr "reservas de carbono" + +#: src/natcap/invest/carbon.py:144 +#, fuzzy +msgid "" +"The calendar year of the current scenario depicted in the current LULC " +"map. Required if Run Valuation model is selected." +msgstr "" +"El año calendario del escenario actual representado en el mapa LULC " +"actual. Es necesario si se selecciona el modelo de ejecución de " +"valoración." + +#: src/natcap/invest/carbon.py:147 +msgid "current LULC year" +msgstr "año LULC actual" + +#: src/natcap/invest/carbon.py:154 +#, fuzzy +msgid "" +"The calendar year of the future scenario depicted in the future LULC map." +" Required if Run Valuation model is selected." +msgstr "" +"El año natural del escenario futuro representado en el mapa LULC futuro. " +"Es necesario si se selecciona el modelo de ejecución de valoración." + +#: src/natcap/invest/carbon.py:162 +msgid "" +"Calculate net present value for the future scenario, and the REDD " +"scenario if provided, and report it in the final HTML document." +msgstr "" +"Calcule el valor actual neto para el escenario futuro, y el escenario " +"REDD si se proporciona, e infórmelo en el documento HTML final." + +#: src/natcap/invest/carbon.py:166 +msgid "run valuation model" +msgstr "correr el modelo de valoración" + +#: src/natcap/invest/carbon.py:172 +#, fuzzy +msgid "The present value of carbon. Required if Run Valuation model is selected." +msgstr "" +"El valor actual del carbono. Se necesita si se selecciona el modelo de " +"ejecución de valoración." + +#: src/natcap/invest/carbon.py:175 +msgid "price of carbon" +msgstr "precio del carbono" + +#: src/natcap/invest/carbon.py:180 +#, fuzzy +msgid "" +"The annual market discount rate in the price of carbon, which reflects " +"society's preference for immediate benefits over future benefits. " +"Required if Run Valuation model is selected." +msgstr "" +"La tasa de descuento anual del mercado en el precio del carbono, que " +"refleja la preferencia de la sociedad por los beneficios inmediatos " +"frente a los futuros. Requerido si se selecciona el modelo de ejecución " +"de valoración." + +#: src/natcap/invest/carbon.py:185 +msgid "annual market discount rate" +msgstr "tasa de descuento anual de mercado" + +#: src/natcap/invest/carbon.py:190 +#, fuzzy +msgid "" +"The relative annual increase of the price of carbon. Required if Run " +"Valuation model is selected." +msgstr "" +"El incremento anual relativo del precio del carbono. Requerido si se " +"selecciona el modelo de ejecución de valoración." + +#: src/natcap/invest/carbon.py:193 +msgid "annual price change" +msgstr "variación anual de precios" + +#: src/natcap/invest/cli.py:56 +msgid "Available models:" +msgstr "Modelos disponibles:" + +#: src/natcap/invest/coastal_vulnerability.py:36 +msgid "Must be a polyline vector" +msgstr "Debe ser un vector polilínea" + +#: src/natcap/invest/coastal_vulnerability.py:37 +msgid "Must be a point or multipoint geometry." +msgstr "Debe ser una geometría de punto o multipunto." + +# In all this there is some coding error I don´t get. The translation itself +# is correct. +#: src/natcap/invest/coastal_vulnerability.py:93 +#, python-format +msgid "" +"Proportion of the highest 10% of wind speeds in the record of interest " +"that blow in the direction of each sector." +msgstr "" +"Proporción del 10% más alto de las velocidades de viento en el registro " +"de interés que soplan en la dirección de cada sector." + +#: src/natcap/invest/coastal_vulnerability.py:100 +#, python-format +msgid "" +"Average of the highest 10% of wind speeds that blow in the direction of " +"each sector." +msgstr "" +"Promedio del 10% más alto de las velocidades de viento que soplan en la " +"dirección de cada sector." + +#: src/natcap/invest/coastal_vulnerability.py:105 +#, python-format +msgid "" +"Proportion of the highest 10% of wave power values on record that are in " +"each sector." +msgstr "" +"Proporción del 10% más alto de los valores de potencia de olas " +"registrados que se encuentran en cada sector." + +#: src/natcap/invest/coastal_vulnerability.py:111 +#, python-format +msgid "" +"Average of the highest 10% of wave power values on record in the " +"direction of each sector." +msgstr "" +"Promedio del 10% más alto de valores de potencia de olas registrados en " +"la dirección de cada sector." + +#: src/natcap/invest/coastal_vulnerability.py:116 +#, fuzzy, python-format +msgid "" +"Average of the highest 10% of wind speeds that are centered on each main " +"sector direction X." +msgstr "" +"Promedio del 10% más alto de velocidades de viento centradas en cada " +"dirección X de sector principal." + +#: src/natcap/invest/coastal_vulnerability.py:145 +msgid "Map of the region over which to run the model." +msgstr "Mapa de la región sobre la que se ejecuta el modelo." + +#: src/natcap/invest/coastal_vulnerability.py:151 +msgid "Interval at which to space shore points along the coastline." +msgstr "" +"Intervalo en el que se espacian los puntos de la orilla a lo largo de la " +"línea de costa." + +#: src/natcap/invest/coastal_vulnerability.py:153 +msgid "model resolution" +msgstr "resolución del modelo" + +#: src/natcap/invest/coastal_vulnerability.py:159 +msgid "" +"Map of all landmasses in and around the region of interest. It is not " +"recommended to clip this landmass to the AOI polygon because some " +"functions in the model require searching for landmasses around shore " +"points up to the distance defined in Maximum Fetch Distance, which likely" +" extends beyond the AOI polygon." +msgstr "" +"Mapa de todas las masas de tierra en y alrededor de la región de interés." +" No se recomienda recortar esta masa de tierra al polígono ADI porque " +"algunas funciones en el modelo requieren la búsqueda de masas de tierra " +"alrededor de los puntos de la costa hasta la distancia definida en la " +"distancia máxima de búsqueda, que probablemente se extiende más allá del " +"polígono AOI." + +#: src/natcap/invest/coastal_vulnerability.py:166 +msgid "landmasses" +msgstr "masas de tierra" + +#: src/natcap/invest/coastal_vulnerability.py:172 +msgid "" +"Map of gridded wind and wave data that represent storm conditions. This " +"global dataset is provided with the InVEST sample data. There are 80 " +"required columns; each of the 5 types is repeated for each sixteenth " +"sector of the 360° compass: " +"[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For example:" +" REI_PCT0, V10PCT_90." +msgstr "" +"Mapa de datos cuadriculados de viento y oleaje que representan las " +"condiciones de las tormentas. Este conjunto de datos globales se " +"proporciona con los datos de muestra de InVEST. Hay 80 columnas " +"necesarias; cada uno de los 5 tipos se repite para cada decimosexto " +"sector de la brújula de 360°: " +"[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. Por ejemplo " +"REI_PCT0, V10PCT_90." + +#: src/natcap/invest/coastal_vulnerability.py:180 +msgid "WaveWatchIII" +msgstr "WaveWatchIII" + +#: src/natcap/invest/coastal_vulnerability.py:186 +msgid "" +"Maximum distance in meters to extend rays from shore points. Points with " +"rays equal to this distance accumulate ocean- driven wave exposure along " +"those rays and local-wind-driven wave exposure along the shorter rays." +msgstr "" +"Distancia máxima en metros para extender los rayos desde los puntos de la" +" costa. Los puntos con rayos iguales a esta distancia acumulan la " +"exposición a las olas impulsadas por el océano a lo largo de esos rayos y" +" la exposición a las olas impulsadas por el viento local a lo largo de " +"los rayos más cortos." + +#: src/natcap/invest/coastal_vulnerability.py:191 +msgid "maximum fetch distance" +msgstr "distancia máxima de alcance" + +#: src/natcap/invest/coastal_vulnerability.py:199 +msgid "" +"Map of bathymetry (ocean depth). Bathymetry values should be negative, " +"and any positive values will be ignored. This should cover the area " +"extending beyond the AOI to the maximum fetch distance." +msgstr "" +"Mapa de batimetría (profundidad del océano). Los valores de la batimetría" +" deben ser negativos, y cualquier valor positivo será ignorado. Debe " +"abarcar la zona que se extiende más allá del ADI hasta la distancia " +"máxima de alcance." + +#: src/natcap/invest/coastal_vulnerability.py:205 +msgid "Bathymetry" +msgstr "Batimetría" + +#: src/natcap/invest/coastal_vulnerability.py:211 +msgid "" +"Map of the edges of the continental shelf or other locally relevant " +"bathymetry contour." +msgstr "" +"Mapa de los bordes de la plataforma continental u otro contorno " +"batimétrico localmente relevante." + +#: src/natcap/invest/coastal_vulnerability.py:214 +msgid "continental shelf contour" +msgstr "contorno de la plataforma continental" + +#: src/natcap/invest/coastal_vulnerability.py:222 +msgid "" +"Map of elevation above sea level on land. This should cover the area " +"extending beyond the AOI by at least the elevation averaging radius. " +"Elevation may be measured in any unit." +msgstr "" +"Mapa de elevación sobre el nivel del mar en tierra. Debe cubrir el área " +"que se extiende más allá del ADI por lo menos el radio de promedio de " +"elevación. La elevación puede medirse en cualquier unidad." + +#: src/natcap/invest/coastal_vulnerability.py:231 +msgid "" +"A radius around each shore point within which to average the elevation " +"values in the DEM raster." +msgstr "" +"Un radio alrededor de cada punto de la costa dentro del cual se promedian" +" los valores de elevación en el ráster MDE." + +#: src/natcap/invest/coastal_vulnerability.py:234 +msgid "elevation averaging radius" +msgstr "radio de promedio de elevación" + +#: src/natcap/invest/coastal_vulnerability.py:241 +msgid "Unique name for the habitat. No spaces allowed." +msgstr "Nombre único para el hábitat. No se permiten espacios." + +#: src/natcap/invest/coastal_vulnerability.py:247 +msgid "" +"Map of area(s) where the habitat is present. If raster, presence of the " +"habitat can be represented by any value and absence of the habitat can be" +" represented by 0 and nodata values." +msgstr "" +"Mapa de la(s) zona(s) donde está presente el hábitat. Si se trata de un " +"raster, la presencia del hábitat puede representarse con cualquier valor " +"y la ausencia del hábitat puede representarse con valores 0 y nodata." + +#: src/natcap/invest/coastal_vulnerability.py:254 +#, fuzzy +msgid "" +"Relative amount of coastline protection this habitat provides, from 1 " +"(very high protection) to 5 (very low protection." +msgstr "" +"Cantidad relativa de protección de la línea de costa que proporciona este" +" hábitat." + +#: src/natcap/invest/coastal_vulnerability.py:263 +msgid "" +"The distance beyond which this habitat will provide no protection to the " +"coastline." +msgstr "" +"La distancia más allá de la cual este hábitat no proporcionará ninguna " +"protección a la línea de costa." + +#: src/natcap/invest/coastal_vulnerability.py:269 +msgid "Table that specifies spatial habitat data and parameters." +msgstr "Tabla que especifica los datos y parámetros espaciales del hábitat." + +#: src/natcap/invest/coastal_vulnerability.py:271 +msgid "habitats table" +msgstr "tabla de hábitats" + +#: src/natcap/invest/coastal_vulnerability.py:279 +#: src/natcap/invest/coastal_vulnerability.py:416 +msgid "very low exposure" +msgstr "exposición muy baja" + +#: src/natcap/invest/coastal_vulnerability.py:280 +#: src/natcap/invest/coastal_vulnerability.py:417 +msgid "low exposure" +msgstr "exposición baja" + +#: src/natcap/invest/coastal_vulnerability.py:281 +#: src/natcap/invest/coastal_vulnerability.py:418 +msgid "moderate exposure" +msgstr "exposición moderada" + +#: src/natcap/invest/coastal_vulnerability.py:282 +#: src/natcap/invest/coastal_vulnerability.py:419 +msgid "high exposure" +msgstr "exposición alta" + +#: src/natcap/invest/coastal_vulnerability.py:283 +#: src/natcap/invest/coastal_vulnerability.py:420 +msgid "very high exposure" +msgstr "exposición muy alta" + +#: src/natcap/invest/coastal_vulnerability.py:285 +#: src/natcap/invest/coastal_vulnerability.py:422 +msgid "Relative exposure of the segment of coastline." +msgstr "Exposición relativa del segmento de costa." + +#: src/natcap/invest/coastal_vulnerability.py:290 +msgid "Map of relative exposure of each segment of coastline." +msgstr "Mapa de la exposición relativa de cada segmento de costa." + +#: src/natcap/invest/coastal_vulnerability.py:291 +msgid "geomorphology" +msgstr "geomorfología" + +#: src/natcap/invest/coastal_vulnerability.py:296 +msgid "1: very low exposure" +msgstr "1: exposición muy baja" + +#: src/natcap/invest/coastal_vulnerability.py:297 +msgid "2: low exposure" +msgstr "2: exposición baja" + +#: src/natcap/invest/coastal_vulnerability.py:298 +msgid "3: moderate exposure" +msgstr "3: exposición moderada" + +#: src/natcap/invest/coastal_vulnerability.py:299 +msgid "4: high exposure" +msgstr "4: exposición alta" + +#: src/natcap/invest/coastal_vulnerability.py:300 +msgid "5: very high exposure" +msgstr "5: exposición muy alta" + +#: src/natcap/invest/coastal_vulnerability.py:303 +msgid "" +"Exposure rank to assign to any shore points that are not near to any " +"segment in the geomorphology vector. Required if a Geomorphology vector " +"is provided." +msgstr "" +"Rango de exposición para asignar a cualquier punto de la costa que no " +"esté cerca de ningún segmento en el vector geomorfológico. Es necesario " +"si se proporciona un vector geomorfológico." + +#: src/natcap/invest/coastal_vulnerability.py:307 +msgid "geomorphology fill value" +msgstr "valor de relleno geomorfológico" + +#: src/natcap/invest/coastal_vulnerability.py:315 +msgid "Map of total human population on each pixel." +msgstr "Mapa de la población humana total en cada píxel." + +#: src/natcap/invest/coastal_vulnerability.py:316 +msgid "human population" +msgstr "población humana" + +#: src/natcap/invest/coastal_vulnerability.py:323 +msgid "" +"The radius around each shore point within which to compute the average " +"population density. Required if a Human Population map is provided." +msgstr "" +"El radio alrededor de cada punto de la costa dentro del cual se calcula " +"la densidad media de población. Es necesario si se proporciona un mapa de" +" población humana." + +#: src/natcap/invest/coastal_vulnerability.py:327 +msgid "population search radius" +msgstr "radio de búsqueda de la población" + +#: src/natcap/invest/coastal_vulnerability.py:333 +msgid "" +"Sea level rise rate or amount. This field name must be chosen as the Sea " +"Level Rise Field." +msgstr "" +"Tasa o cantidad de aumento del nivel del mar. Este nombre de campo debe " +"elegirse como campo de aumento del nivel del mar." + +#: src/natcap/invest/coastal_vulnerability.py:342 +msgid "" +"Map of sea level rise rates or amounts. May be any sea level rise metric " +"of interest, such as rate, or net rise/fall." +msgstr "" +"Mapa de las tasas o cantidades de aumento del nivel del mar. Puede ser " +"cualquier métrica de aumento del nivel del mar de interés, como la tasa o" +" el aumento/descenso neto." + +#: src/natcap/invest/coastal_vulnerability.py:345 +msgid "sea level rise" +msgstr "aumento del nivel del mar" + +#: src/natcap/invest/coastal_vulnerability.py:351 +msgid "" +"Name of the field in the sea level rise vector which contains the sea " +"level rise metric of interest. Required if a Sea Level Rise vector is " +"provided." +msgstr "" +"Nombre del campo del vector de aumento del nivel del mar que contiene la " +"métrica de aumento del nivel del mar de interés. Es obligatorio si se " +"proporciona un vector de aumento del nivel del mar." + +#: src/natcap/invest/coastal_vulnerability.py:355 +msgid "sea level rise field" +msgstr "campo de aumento del nivel del mar" + +#: src/natcap/invest/crop_production_percentile.py:135 +msgid "" +"A table that maps each LULC code from the LULC map to one of the 175 " +"canonical crop names representing the crop grown in that LULC class." +msgstr "" +"Una tabla que asigna cada código LULC del mapa LULC a uno de los 175 " +"nombres de cultivos canónicos que representan el cultivo realizado en esa" +" clase LULC." + +#: src/natcap/invest/crop_production_percentile.py:139 +msgid "LULC to Crop Table" +msgstr "Tabla de LULC a cultivos" + +#: src/natcap/invest/crop_production_percentile.py:151 +msgid "Table mapping each climate bin to yield percentiles for each crop." +msgstr "" +"Tabla que relaciona cada casilla climática con los percentiles de " +"rendimiento de cada cultivo." + +#: src/natcap/invest/crop_production_percentile.py:182 +#: src/natcap/invest/crop_production_regression.py:169 +msgid "Maps of climate bins for each crop." +msgstr "Mapas de los intervalos climáticos para cada cultivo." + +#: src/natcap/invest/crop_production_percentile.py:192 +#: src/natcap/invest/crop_production_regression.py:179 +msgid "Maps of actual observed yield for each crop." +msgstr "Mapas de rendimiento real observado para cada cultivo." + +#: src/natcap/invest/crop_production_percentile.py:221 +msgid "Path to the InVEST Crop Production Data directory." +msgstr "Ruta de acceso al directorio de datos de producción de cultivos de InVEST." + +#: src/natcap/invest/crop_production_percentile.py:222 +msgid "model data directory" +msgstr "directorio de datos del modelo" + +#: src/natcap/invest/crop_production_regression.py:22 +msgid "barley" +msgstr "cebada" + +#: src/natcap/invest/crop_production_regression.py:23 +msgid "maize" +msgstr "maíz" + +#: src/natcap/invest/crop_production_regression.py:24 +msgid "oil palm" +msgstr "palma aceitera" + +#: src/natcap/invest/crop_production_regression.py:25 +msgid "potato" +msgstr "papa" + +#: src/natcap/invest/crop_production_regression.py:26 +msgid "rice" +msgstr "arroz" + +#: src/natcap/invest/crop_production_regression.py:27 +msgid "soybean" +msgstr "soya" + +#: src/natcap/invest/crop_production_regression.py:28 +msgid "sugar beet" +msgstr "remolacha azucarera" + +#: src/natcap/invest/crop_production_regression.py:29 +msgid "sugarcane" +msgstr "caña de azúcar" + +#: src/natcap/invest/crop_production_regression.py:30 +msgid "wheat" +msgstr "trigo" + +#: src/natcap/invest/crop_production_regression.py:96 +msgid "" +"A table that maps each LULC code from the LULC map to one of the 10 " +"canonical crop names representing the crop grown in that LULC class." +msgstr "" +"Una tabla que asigna cada código LULC del mapa LULC a uno de los 10 " +"nombres de cultivos canónicos que representan el cultivo realizado en esa" +" clase LULC." + +#: src/natcap/invest/crop_production_regression.py:100 +msgid "LULC to crop table" +msgstr "Tabla de LULC a cultivos" + +#: src/natcap/invest/crop_production_regression.py:109 +msgid "One of the supported crop types." +msgstr "Uno de los tipos de cultivo admitidos." + +#: src/natcap/invest/crop_production_regression.py:117 +msgid "A table that maps crops to fertilizer application rates." +msgstr "" +"Una tabla que relaciona los cultivos con las tasas de aplicación de " +"fertilizantes." + +#: src/natcap/invest/crop_production_regression.py:119 +msgid "fertilization rate table" +msgstr "tabla de tasas de fertilización" + +#: src/natcap/invest/crop_production_regression.py:191 +msgid "The Crop Production datasets provided with the model." +msgstr "" +"Los conjuntos de datos de producción de cultivos que se proporcionan con " +"el modelo." + +#: src/natcap/invest/crop_production_regression.py:192 +msgid "model data" +msgstr "datos del modelo" + +# In this case I am not sure about translatingf the selected item. +#: src/natcap/invest/forest_carbon_edge_effect.py:51 +#, fuzzy +msgid "" +"Number of closest regression models that are used when calculating the " +"total biomass. Each local model is linearly weighted by distance such " +"that the pixel's biomass is a function of each of these points with the " +"closest point having the largest effect. Must be an integer greater than " +"0. Required if Compute Forest Edge Effects is selected." +msgstr "" +"Número de modelos de regresión más cercanos que se utilizan al calcular " +"la biomasa total. Cada modelo local está ponderado linealmente por la " +"distancia, de manera que la biomasa del píxel es una función de cada uno " +"de estos puntos, teniendo el punto más cercano el mayor efecto. Debe ser " +"un número entero mayor que 0. Se necesita si se selecciona el cálculo de " +"efectos de borde de bosque." + +#: src/natcap/invest/forest_carbon_edge_effect.py:59 +msgid "number of points to average" +msgstr "número de puntos a promediar" + +#: src/natcap/invest/forest_carbon_edge_effect.py:73 +msgid "" +"Enter 1 if the LULC class is tropical forest, 0 if it is not tropical " +"forest." +msgstr "" +"Introduzca 1 si la clase LULC es bosque tropical, 0 si no es bosque " +"tropical." + +#: src/natcap/invest/forest_carbon_edge_effect.py:79 +msgid "Carbon density value for the aboveground carbon pool." +msgstr "" +"Valor de la densidad del carbono para la reserva de carbono sobre el " +"suelo." + +#: src/natcap/invest/forest_carbon_edge_effect.py:87 +msgid "" +"Carbon density value for the belowground carbon pool. Required if " +"calculating all pools." +msgstr "" +"Valor de la densidad del carbono para la reserva de carbono subterránea. " +"Es necesario si se calculan todas las reservas." + +#: src/natcap/invest/forest_carbon_edge_effect.py:95 +msgid "" +"Carbon density value for the soil carbon pool. Required if calculating " +"all pools." +msgstr "" +"Valor de la densidad del carbono para la reserva de carbono del suelo. Es" +" necesario si se calculan todas las reservas." + +#: src/natcap/invest/forest_carbon_edge_effect.py:103 +msgid "" +"Carbon density value for the dead matter carbon pool. Required if " +"calculating all pools." +msgstr "" +"Valor de la densidad del carbono para la reserva de carbono de la materia" +" muerta. Es necesario si se calculan todas las reservas." + +#: src/natcap/invest/forest_carbon_edge_effect.py:108 +msgid "" +"A table mapping each LULC code from the LULC map to biophysical data for " +"that LULC class." +msgstr "" +"Una tabla que relaciona cada código LULC del mapa LULC con los datos " +"biofísicos de esa clase LULC." + +#: src/natcap/invest/forest_carbon_edge_effect.py:124 +msgid "all" +msgstr "todos" + +#: src/natcap/invest/forest_carbon_edge_effect.py:125 +msgid "" +"Use all pools (aboveground, belowground, soil, and dead matter) in the " +"carbon pool calculation." +msgstr "" +"Utilice todas las reservas (sobre el suelo, bajo el suelo, suelo y " +"materia muerta) en el cálculo del depósito de carbono." + +#: src/natcap/invest/forest_carbon_edge_effect.py:129 +msgid "aboveground only" +msgstr "solo en la superficie" + +#: src/natcap/invest/forest_carbon_edge_effect.py:130 +msgid "Only use the aboveground pool in the carbon pool calculation." +msgstr "" +"Solo utilice la reserva sobre el suelo en el cálculo de la reserva de " +"carbono." + +#: src/natcap/invest/forest_carbon_edge_effect.py:134 +msgid "Which carbon pools to consider." +msgstr "Qué reservas de carbono hay que tener en cuenta." + +#: src/natcap/invest/forest_carbon_edge_effect.py:135 +msgid "carbon pools to calculate" +msgstr "reservas de carbono a calcular" + +#: src/natcap/invest/forest_carbon_edge_effect.py:139 +msgid "Account for forest edge effects on aboveground carbon." +msgstr "" +"Tanga en cuenta los efectos de los bordes del bosque sobre el carbono " +"sobre el suelo." + +#: src/natcap/invest/forest_carbon_edge_effect.py:140 +msgid "compute forest edge effects" +msgstr "calcule los efectos de los bordes del bosque" + +#: src/natcap/invest/forest_carbon_edge_effect.py:148 +msgid "asymptotic" +msgstr "asintótico" + +#: src/natcap/invest/forest_carbon_edge_effect.py:149 +msgid "logarithmic" +msgstr "logarítmico" + +#: src/natcap/invest/forest_carbon_edge_effect.py:150 +msgid "linear" +msgstr "lineal" + +#: src/natcap/invest/forest_carbon_edge_effect.py:152 +msgid "Optimal regression model for the area." +msgstr "Modelo de regresión óptimo para la zona." + +#: src/natcap/invest/forest_carbon_edge_effect.py:157 +msgid "θ₁ parameter for the regression equation." +msgstr "parámetro θ₁ para la ecuación de regresión." + +#: src/natcap/invest/forest_carbon_edge_effect.py:161 +msgid "θ₂ parameter for the regression equation." +msgstr "parámetro θ₂ para la ecuación de regresión." + +#: src/natcap/invest/forest_carbon_edge_effect.py:165 +msgid "" +"θ₃ parameter for the regression equation. Used only for the asymptotic " +"model." +msgstr "" +"parámetro θ₃ para la ecuación de regresión. Se utiliza solamente para el " +"modelo asintótico." + +# Idem +#: src/natcap/invest/forest_carbon_edge_effect.py:171 +#, fuzzy +msgid "" +"Map storing the optimal regression model for each tropical subregion and " +"the corresponding theta parameters for that regression equation. Default " +"data is provided. Required if Compute Forest Edge Effects is selected." +msgstr "" +"Mapa que almacena el modelo de regresión óptimo para cada subregión " +"tropical y los parámetros theta correspondientes para esa ecuación de " +"regresión. Se proporcionan datos por defecto. Es necesario si se " +"selecciona la opción de calcular los efectos de los bordes del bosque." + +#: src/natcap/invest/forest_carbon_edge_effect.py:176 +msgid "global regression models" +msgstr "modelos de regresión global" + +#: src/natcap/invest/forest_carbon_edge_effect.py:181 +#, fuzzy +msgid "" +"Proportion of forest edge biomass that is elemental carbon. Required if " +"Compute Forest Edge Effects is selected." +msgstr "" +"Proporción de la biomasa del borde del bosque que es carbono elemental. " +"Es necesaria si se selecciona la opción de calcular los efectos del " +"borde del bosque." + +#: src/natcap/invest/forest_carbon_edge_effect.py:184 +msgid "forest edge biomass to carbon conversion factor" +msgstr "factor de conversión de la biomasa del borde del bosque en carbono" + +#: src/natcap/invest/habitat_quality.py:21 +#, fuzzy +msgid "" +"Threats {threats} does not match any column in the sensitivity table. " +"Sensitivity columns: {column_names}" +msgstr "" +"Amenazas {threats} no coincide con ninguna columna de la tabla de " +"sensibilidad. Columnas de sensibilidad: {column_names}" + +#: src/natcap/invest/habitat_quality.py:24 +#, fuzzy +msgid "" +"A threat raster for threats: {threat_list} was not found or it could not " +"be opened by GDAL." +msgstr "" +"No se halló un ráster de amenazas para las amenazas: {threat_list} o no " +"pudo ser abierta por GDAL." + +#: src/natcap/invest/habitat_quality.py:27 +msgid "Threat paths must be unique. Duplicates: " +msgstr "Las rutas de las amenazas deben ser únicas. Duplicados: " + +#: src/natcap/invest/habitat_quality.py:46 +msgid "" +"Map of LULC at present. All values in this raster must have corresponding" +" entries in the Sensitivity table." +msgstr "" +"Mapa de LULC en la actualidad. Todos los valores de este raster deben " +"tener los inputs correspondientes en la tabla de sensibilidad." + +#: src/natcap/invest/habitat_quality.py:49 +msgid "current land cover" +msgstr "cobertura del suelo actual" + +#: src/natcap/invest/habitat_quality.py:55 +msgid "" +"Map of LULC in a future scenario. All values in this raster must have " +"corresponding entries in the Sensitivity Table. Must use the same " +"classification scheme and codes as in the Current LULC map." +msgstr "" +"Mapa de LULC en un escenario futuro. Todos los valores de este ráster " +"deben tener los inputs correspondientes en la Tabla de Sensibilidad. Debe" +" utilizar el mismo esquema de clasificación y códigos que en el mapa LULC" +" actual." + +#: src/natcap/invest/habitat_quality.py:60 +msgid "future land cover" +msgstr "cobertura futura del suelo" + +#: src/natcap/invest/habitat_quality.py:66 +msgid "" +"Map of LULC in a baseline scenario, when intensive landscape management " +"was relatively rare. All values in this raster must have corresponding " +"entries in the Sensitivity table. Must use the same classification scheme" +" and codes as in the Current LULC map." +msgstr "" +"Mapa de LULC en un escenario de referencia, cuando la gestión intensiva " +"del paisaje era relativamente rara. Todos los valores de este ráster " +"deben tener los inputs correspondientes en la tabla de sensibilidad. Debe" +" utilizar el mismo esquema de clasificación y códigos del mapa LULC " +"actual." + +#: src/natcap/invest/habitat_quality.py:72 +msgid "baseline land cover" +msgstr "cobertura terrestre de línea de base" + +#: src/natcap/invest/habitat_quality.py:80 +msgid "" +"Name of the threat. Each threat name must have a corresponding column in " +"the Sensitivity table." +msgstr "" +"Nombre de la amenaza. Cada nombre de amenaza debe tener una columna " +"correspondiente en la tabla de sensibilidad." + +#: src/natcap/invest/habitat_quality.py:86 +msgid "" +"The maximum distance over which each threat affects habitat quality. The " +"impact of each degradation source will decline to zero at this maximum " +"distance. This value must be greater than or equal to the pixel size of " +"your LULC raster(s)." +msgstr "" +"La distancia máxima a la que cada amenaza afecta a la calidad del " +"hábitat. El impacto de cada fuente de degradación se reducirá a cero en " +"esta distancia máxima. Este valor debe ser mayor o igual que el tamaño " +"del píxel de lo(s) ráster(s) LULC." + +#: src/natcap/invest/habitat_quality.py:95 +msgid "The impact of each threat on habitat quality, relative to other threats." +msgstr "" +"El impacto de cada amenaza en la calidad del hábitat, en relación con " +"otras amenazas." + +#: src/natcap/invest/habitat_quality.py:103 +msgid "Effects of the threat decay linearly with distance from the threat." +msgstr "" +"Los efectos de la amenaza decaen linealmente con la distancia a la " +"amenaza." + +#: src/natcap/invest/habitat_quality.py:107 +msgid "Effects of the threat decay exponentially with distance from the threat." +msgstr "Los efectos de la amenaza decaen exponencialmente con la distancia a esta." + +#: src/natcap/invest/habitat_quality.py:111 +msgid "The type of decay over space for each threat." +msgstr "El tipo de decaimiento a lo largo del espacio para cada amenaza." + +#: src/natcap/invest/habitat_quality.py:116 +#, fuzzy +msgid "" +"Path to a raster of the threat's distribution in the current scenario. " +"Each pixel value in this raster is the relative intensity of the threat " +"at that location, with values between 0 and 1." +msgstr "" +"Mapa de la distribución de la amenaza en el escenario actual. El valor de" +" cada píxel es la intensidad relativa de la amenaza en ese lugar. " + +#: src/natcap/invest/habitat_quality.py:127 +#, fuzzy +msgid "" +"Path to a raster of the threat's distribution in a future scenario. Each " +"pixel value in this raster is the relative intensity of the threat at " +"that location, with values between 0 and 1." +msgstr "" +"Mapa de la distribución de la amenaza en el escenario actual. El valor de" +" cada píxel es la intensidad relativa de la amenaza en ese lugar. " + +#: src/natcap/invest/habitat_quality.py:138 +#, fuzzy +msgid "" +"Path to a raster of the threat's distribution in the baseline scenario. " +"Each pixel value in this raster is the relative intensity of the threat " +"at that location, with values between 0 and 1. Required if Baseline LULC " +"is provided." +msgstr "" +"Mapa de la distribución de la amenaza en el escenario base. El valor de " +"cada píxel es la intensidad relativa de la amenaza en ese lugar. " +"Necesario si se proporciona el LULC de referencia." + +#: src/natcap/invest/habitat_quality.py:146 +msgid "" +"Table mapping each threat of interest to its properties and distribution " +"maps. Paths are relative to the threats table path." +msgstr "" +"Tabla que relaciona cada amenaza de interés con sus propiedades y mapas " +"de distribución. Las rutas son relativas a la ruta de la tabla de " +"amenazas." + +#: src/natcap/invest/habitat_quality.py:150 +msgid "threats table" +msgstr "tabla de amenazas" + +#: src/natcap/invest/habitat_quality.py:158 +msgid "" +"The region's relative accessibility to threats, where 0 represents " +"completely inaccessible and 1 represents completely accessible." +msgstr "" +"La accesibilidad relativa de la región a las amenazas, en la que 0 " +"representa que es completamente inaccesible y 1 que es completamente " +"accesible." + +#: src/natcap/invest/habitat_quality.py:166 +msgid "" +"Map of the relative protection that legal, institutional, social, and " +"physical barriers provide against threats. Any cells not covered by a " +"polygon will be set to 1." +msgstr "" +"Mapa de la protección relativa que ofrecen las barreras legales, " +"institucionales, sociales y físicas contra las amenazas. Las celdas que " +"no estén cubiertas por un polígono se establecerán en 1." + +#: src/natcap/invest/habitat_quality.py:170 +msgid "accessibility to threats" +msgstr "accesibilidad a las amenazas" + +#: src/natcap/invest/habitat_quality.py:183 +msgid "" +"Suitability of this LULC class as habitat, where 0 is not suitable and 1 " +"is completely suitable." +msgstr "" +"Aptitud de esta clase de LULC como hábitat, donde 0 es no apto y 1 es " +"completamente apto." + +#: src/natcap/invest/habitat_quality.py:189 +#, fuzzy +msgid "" +"The relative sensitivity of each LULC class to each type of threat, where" +" 1 represents high sensitivity and 0 represents that it is unaffected. " +"There must be one threat column for each threat name in the 'threats' " +"column of the Threats Table." +msgstr "" +"La sensibilidad relativa de cada clase de LULC a cada tipo de amenaza, " +"donde 1 representa una alta sensibilidad y 0 representa que no le afecta." +" Debe haber una columna de amenazas por cada nombre de amenaza en la " +"columna \"amenazas\" de la Tabla de Amenazas." + +#: src/natcap/invest/habitat_quality.py:197 +msgid "" +"Table mapping each LULC class to data about the species' habitat " +"preference and threat sensitivity in areas with that LULC." +msgstr "" +"Tabla que relaciona cada clase de LULC con los datos sobre la preferencia" +" de hábitat de la especie y la sensibilidad a las amenazas en zonas con " +"ese LULC." + +#: src/natcap/invest/habitat_quality.py:201 +msgid "sensitivity table" +msgstr "tabla de sensibilidad" + +#: src/natcap/invest/habitat_quality.py:207 +msgid "Half-saturation constant used in the degradation equation." +msgstr "Constante de semisaturación utilizada en la ecuación de degradación." + +#: src/natcap/invest/habitat_quality.py:209 +msgid "half-saturation constant" +msgstr "constante de semisaturación" + +#: src/natcap/invest/hra.py:61 +msgid "habitat stressor table" +msgstr "tabla de factores de estrés del hábitat" + +#: src/natcap/invest/hra.py:62 +msgid "A table describing each habitat and stressor." +msgstr "Una tabla que describe cada hábitat y factor de estrés." + +#: src/natcap/invest/hra.py:68 +#, fuzzy +msgid "" +"A unique name for each habitat or stressor. These names must match the " +"habitat and stressor names in the Criteria Scores Table." +msgstr "" +"Un nombre único para cada hábitat o factor de estrés. Estos nombres deben" +" coincidir con los nombres de los hábitats y de los factores de estrés en" +" la tabla de calificaciones de los criterios." + +#: src/natcap/invest/hra.py:77 +msgid "" +"Pixel values are 1, indicating presence of the habitat/stressor, or 0 " +"indicating absence. Any values besides 0 or 1 will be treated as 0." +msgstr "" +"Los valores de los píxeles son 1, que indica la presencia del " +"hábitat/estrés, o 0, que indica la ausencia. Cualquier valor que no sea 0" +" o 1 se tratará como 0." + +#: src/natcap/invest/hra.py:84 +msgid "" +"Map of where the habitat or stressor exists. For rasters, a pixel value " +"of 1 indicates presence of the habitat or stressor. 0 (or any other " +"value) indicates absence of the habitat or stressor. For vectors, a " +"polygon indicates an area where the habitat or stressor is present." +msgstr "" +"Mapa de dónde existe el hábitat o el factor de estrés. En el caso de los " +"rásters, un valor de píxel de 1 indica la presencia del hábitat o del " +"factor de estrés. 0 (o cualquier otro valor) indica la ausencia del " +"hábitat o del factor de estrés. En el caso de los vectores, un polígono " +"indica un área en la que está presente el hábitat o el factor de estrés." + +#: src/natcap/invest/hra.py:95 +msgid "habitat" +msgstr "hábitat" + +#: src/natcap/invest/hra.py:96 +msgid "stressor" +msgstr "factor de estrés" + +#: src/natcap/invest/hra.py:98 +msgid "Whether this row is for a habitat or a stressor." +msgstr "Si esta fila es para un hábitat o un factor de estrés." + +#: src/natcap/invest/hra.py:104 +msgid "" +"The desired buffer distance used to expand a given stressor’s influence " +"or footprint. This should be left blank for habitats, but must be filled " +"in for stressors. Enter 0 if no buffering is desired for a given " +"stressor. The model will round down this buffer distance to the nearest " +"cell unit. e.g., a buffer distance of 600m will buffer a stressor’s " +"footprint by two grid cells if the resolution of analysis is 250m." +msgstr "" +"La distancia de amortiguamiento deseada para ampliar la influencia o la " +"huella de un factor de estrés determinado. Debe dejarse en blanco para " +"los hábitats, pero debe rellenarse para los factores de estrés. " +"Introduzca 0 si no se desea ningún amortiguamiento para un factor " +"determinado. El modelo redondeará hacia abajo esta distancia de " +"amortiguación a la unidad de celda más cercana. Por ejemplo, una " +"distancia de amortiguación de 600m amortiguará la huella de un factor de " +"estrés en dos celdas de la cuadrícula si la resolución del análisis es de" +" 250m." + +#: src/natcap/invest/hra.py:118 +msgid "criteria scores table" +msgstr "tabla de calificaciones de los criterios" + +#: src/natcap/invest/hra.py:119 +msgid "A table of criteria scores for all habitats and stressors." +msgstr "" +"Una tabla de calificaciones de criterios para todos los hábitats y " +"factores de estrés." + +#: src/natcap/invest/hra.py:124 +msgid "resolution of analysis" +msgstr "resolución del análisis" + +#: src/natcap/invest/hra.py:125 +msgid "" +"The resolution at which to run the analysis. The model outputs will have " +"this resolution." +msgstr "" +"La resolución con la que se ejecuta el análisis. Los resultados del " +"modelo tendrán esta resolución." + +#: src/natcap/invest/hra.py:133 +msgid "maximum criteria score" +msgstr "calificación máxima de los criterios" + +#: src/natcap/invest/hra.py:134 +msgid "The highest possible criteria score in the scoring system." +msgstr "" +"La mayor calificación posible de los criterios en el sistema de " +"calificación." + +#: src/natcap/invest/hra.py:141 +msgid "risk equation" +msgstr "ecuación de riesgo" + +#: src/natcap/invest/hra.py:142 +msgid "The equation to use to calculate risk from exposure and consequence." +msgstr "" +"La ecuación que se debe utilizar para calcular el riesgo a partir de la " +"exposición y las consecuencias." + +#: src/natcap/invest/hra.py:147 +msgid "Multiplicative" +msgstr "Multiplicativo" + +#: src/natcap/invest/hra.py:148 +msgid "Euclidean" +msgstr "Euclidiano" + +#: src/natcap/invest/hra.py:152 +msgid "decay equation" +msgstr "ecuación de decaimiento" + +#: src/natcap/invest/hra.py:153 +msgid "The equation to model effects of stressors in buffer areas." +msgstr "" +"La ecuación para modelizar los efectos de los factores de estrés en las " +"zonas de amortiguamiento." + +#: src/natcap/invest/hra.py:158 +msgid "None" +msgstr "Ninguno" + +#: src/natcap/invest/hra.py:159 +msgid "No decay. Stressor has full effect in the buffer area." +msgstr "" +"No hay decaimiento. El factor tiene pleno efecto en la zona de " +"amortiguación." + +#: src/natcap/invest/hra.py:163 +msgid "Linear" +msgstr "Lineal" + +#: src/natcap/invest/hra.py:164 +msgid "" +"Stressor effects in the buffer area decay linearly with distance from the" +" stressor." +msgstr "" +"Los efectos del factor de estres en la zona de amortiguación decaen " +"linealmente con la distancia al factor." + +#: src/natcap/invest/hra.py:168 +msgid "Exponential" +msgstr "Exponencial" + +#: src/natcap/invest/hra.py:169 +msgid "" +"Stressor effects in the buffer area decay exponentially with distance " +"from the stressor." +msgstr "" +"Los efectos del factor en la zona de amortiguación decaen " +"exponencialmente con la distancia al factor." + +#: src/natcap/invest/hra.py:182 +msgid "" +"Uniquely identifies each feature. Required if the vector contains more " +"than one feature." +msgstr "" +"Identifica de forma exclusiva cada característica. Se necesita si el " +"vector contiene más de una característica." + +#: src/natcap/invest/hra.py:187 +msgid "" +"A GDAL-supported vector file containing features representing one or more" +" planning regions or subregions." +msgstr "" +"Un archivo vectorial compatible con GDAL que contiene características que" +" representan una o más regiones o subregiones de planificación." + +#: src/natcap/invest/hra.py:192 +msgid "Number of Overlapping Stressors" +msgstr "Número de factores de estrés superpuestos" + +#: src/natcap/invest/hra.py:195 +msgid "" +"The number of overlapping stressors to consider as 'maximum' when " +"reclassifying risk scores into high/medium/low. Affects the breaks " +"between risk classifications." +msgstr "" +"El número de factores de estrés superpuestos a considerar como \"máximo\"" +" al reclasificar las calificaciones de riesgo en alto/medio/bajo. Afecta " +"a las rupturas entre las clasificaciones de riesgo." + +#: src/natcap/invest/hra.py:204 +msgid "Generate GeoJSONs" +msgstr "Generar GeoJSONs" + +#: src/natcap/invest/hra.py:205 +msgid "Generate GeoJSON outputs for web visualization." +msgstr "Generar resultados GeoJSON para la visualización web." + +#: src/natcap/invest/model_metadata.py:18 +msgid "Annual Water Yield" +msgstr "Rendimiento anual de agua" + +#: src/natcap/invest/model_metadata.py:24 +msgid "Carbon Storage and Sequestration" +msgstr "Almacenamiento y secuestración de carbono" + +#: src/natcap/invest/model_metadata.py:30 +msgid "Coastal Blue Carbon" +msgstr "Carbono azul costero" + +#: src/natcap/invest/model_metadata.py:36 +msgid "Coastal Blue Carbon Preprocessor" +msgstr "Preprocesador de Carbono azul costero" + +#: src/natcap/invest/model_metadata.py:42 +msgid "Coastal Vulnerability" +msgstr "Vulnerabilidad costera" + +#: src/natcap/invest/model_metadata.py:48 +msgid "Crop Production: Percentile" +msgstr "Producción de cultivos: Percentil" + +#: src/natcap/invest/model_metadata.py:54 +msgid "Crop Production: Regression" +msgstr "Producción de cultivos: Regresión" + +#: src/natcap/invest/model_metadata.py:60 +msgid "DelineateIt" +msgstr "DelineateIt" + +#: src/natcap/invest/model_metadata.py:66 +msgid "Forest Carbon Edge Effect" +msgstr "Efecto de borde del carbono forestal" + +#: src/natcap/invest/model_metadata.py:72 +msgid "Habitat Quality" +msgstr "Calidad del hábitat" + +#: src/natcap/invest/model_metadata.py:78 +msgid "Habitat Risk Assessment" +msgstr "Evaluación del riesgo del hábitat" + +#: src/natcap/invest/model_metadata.py:84 +msgid "Nutrient Delivery Ratio" +msgstr "Proporción de suministro de nutrientes" + +#: src/natcap/invest/model_metadata.py:90 +msgid "Crop Pollination" +msgstr "Polinización de cultivos" + +#: src/natcap/invest/model_metadata.py:96 +msgid "Visitation: Recreation and Tourism" +msgstr "Visitación: Ocio y Turismo" + +#: src/natcap/invest/model_metadata.py:102 +msgid "RouteDEM" +msgstr "RouteDEM" + +#: src/natcap/invest/model_metadata.py:108 +msgid "Scenario Generator: Proximity Based" +msgstr "Generador de escenarios: Basado en la proximidad" + +#: src/natcap/invest/model_metadata.py:114 +msgid "Scenic Quality" +msgstr "Calidad paisajística" + +#: src/natcap/invest/model_metadata.py:120 +msgid "Sediment Delivery Ratio" +msgstr "Tasa de suministro de sedimentos" + +#: src/natcap/invest/model_metadata.py:126 +msgid "Seasonal Water Yield" +msgstr "Rendimiento hídrico estacional" + +#: src/natcap/invest/model_metadata.py:132 +msgid "Urban Stormwater Retention" +msgstr "Retención de aguas pluviales urbanas" + +#: src/natcap/invest/model_metadata.py:138 +msgid "Wave Energy Production" +msgstr "Producción de energía de las olas" + +#: src/natcap/invest/model_metadata.py:144 +msgid "Wind Energy Production" +msgstr "Producción de energía eólica" + +#: src/natcap/invest/model_metadata.py:150 +msgid "Urban Flood Risk Mitigation" +msgstr "Mitigación del riesgo de inundaciones urbanas" + +#: src/natcap/invest/model_metadata.py:156 +msgid "Urban Cooling" +msgstr "Enfriamiento urbano" + +#: src/natcap/invest/model_metadata.py:162 +msgid "Urban Nature Access" +msgstr "" + +#: src/natcap/invest/pollination.py:37 +msgid "" +"Map of LULC codes. All values in this raster must have corresponding " +"entries in the Biophysical Table." +msgstr "" +"Mapa de códigos LULC. Todos los valores de este ráster deben tener los " +"inputs correspondientes en la Tabla Biofísica." + +#: src/natcap/invest/pollination.py:47 +msgid "" +"Unique name or identifier for each pollinator species or guild of " +"interest." +msgstr "" +"Nombre o identificador único para cada especie o gremio de polinizadores " +"de interés." + +#: src/natcap/invest/pollination.py:53 +msgid "" +"Utilization of the substrate by this species, where 1 indicates the " +"nesting substrate is fully utilized and 0 indicates it is not utilized at" +" all. Replace [SUBSTRATE] with substrate names matching those in the " +"Biophysical Table, so that there is a column for each substrate." +msgstr "" +"Utilización del sustrato por parte de esta especie, donde 1 indica que el" +" sustrato de anidación se utiliza completamente y 0 indica que no se " +"utiliza en absoluto. Reemplace [SUSTRATO] con nombres de sustratos que " +"coincidan con los de la Tabla Biofísica, de modo que haya una columna " +"para cada sustrato." + +#: src/natcap/invest/pollination.py:63 +msgid "" +"Pollinator activity for this species/guild in each season. 1 indicates " +"maximum activity for the species/guild, and 0 indicates no activity. " +"Replace [SEASON] with season names matching those in the biophysical " +"table, so that there is a column for each season." +msgstr "" +"Actividad de los polinizadores para esta especie o gremio en cada " +"estación. el 1 indica la máxima actividad de la especie o gremio, y el 0 " +"indica que no hay actividad. Sustituya [ESTACIÓN] por los nombres de las " +"estaciones que coincidan con los de la tabla biofísica, de modo que haya " +"una columna para cada estación." + +#: src/natcap/invest/pollination.py:74 +msgid "Average distance that this species or guild travels to forage on flowers." +msgstr "" +"Distancia media que recorre esta especie o gremio para alimentarse de " +"flores." + +#: src/natcap/invest/pollination.py:80 +msgid "" +"The proportion of total pollinator abundance that consists of this " +"species/guild." +msgstr "" +"La proporción de la abundancia total de polinizadores que consiste en " +"esta especie/gremio." + +#: src/natcap/invest/pollination.py:85 +msgid "" +"A table mapping each pollinator species or guild of interest to its " +"pollination-related parameters." +msgstr "" +"Una tabla que mapea cada especie o gremio de polinizadores de interés con" +" sus parámetros relacionados con la polinización." + +#: src/natcap/invest/pollination.py:88 +msgid "Guild Table" +msgstr "Tabla de gremios" + +#: src/natcap/invest/pollination.py:97 +msgid "" +"Index of availability of the given substrate in this LULC class. Replace " +"[SUBSTRATE] with substrate names matching those in the Guild Table, so " +"that there is a column for each substrate." +msgstr "" +"Índice de disponibilidad del sustrato dado en esta clase LULC. Sustituir " +"[SUSTRATO] por los nombres de los sustratos que coincidan con los de la " +"tabla de gremios, de modo que haya una columna para cada sustrato." + +#: src/natcap/invest/pollination.py:104 +msgid "" +"Abundance of flowers during the given season in this LULC class. This is " +"the proportion of land area covered by flowers, multiplied by the " +"proportion of the season for which there is that coverage. Replace " +"[SEASON] with season names matching those in the Guild Table, so that " +"there is a column for each season." +msgstr "" +"Abundancia de flores durante la estación dada en esta clase de LULC. Se " +"trata de la proporción de superficie cubierta por flores, multiplicada " +"por la proporción de la estación para la que existe esa cobertura. " +"Sustituya [ESTACIÓN] por los nombres de las estaciones que coincidan con " +"los de la tabla de gremios, de modo que haya una columna para cada " +"estación." + +#: src/natcap/invest/pollination.py:113 +msgid "" +"A table mapping each LULC class to nesting availability and floral " +"abundance data for each substrate and season in that LULC class. All " +"values in the LULC raster must have corresponding entries in this table." +msgstr "" +"Una tabla que relacione cada clase de LULC con los datos de " +"disponibilidad de nidos y abundancia de flores para cada sustrato y " +"estación en esa clase de LULC. Todos los valores de la trama LULC deben " +"tener sus correspondientes inputs en esta tabla." + +#: src/natcap/invest/pollination.py:125 +msgid "" +"Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', " +"etc." +msgstr "" + +#: src/natcap/invest/pollination.py:130 +msgid "" +"The half saturation coefficient for the crop grown in this area. This is " +"the wild pollinator abundance (i.e. the proportion of all pollinators " +"that are wild) needed to reach half of the total potential pollinator-" +"dependent yield." +msgstr "" +"El coeficiente de media saturación para el cultivo que se produce en esta" +" zona. Se trata de la abundancia de polinizadores silvestres (es decir, " +"la proporción de todos los polinizadores que son silvestres) necesaria " +"para alcanzar la mitad del rendimiento total potencial dependiente de los" +" polinizadores." + +#: src/natcap/invest/pollination.py:138 +#, fuzzy +msgid "" +"The season in which the crop is pollinated. Season names must match those" +" in the Guild Table and Biophysical Table." +msgstr "" +"La estación en la que se poliniza el cultivo. Los nombres de las " +"estaciones deben coincidir con los de la Tabla de gremios y la Tabla " +"biofísica." + +#: src/natcap/invest/pollination.py:144 +msgid "" +"The floral resources available at this farm for the given season. Replace" +" [SEASON] with season names matching those in the Guild Table and " +"Biophysical Table, so that there is one field for each season." +msgstr "" +"Los recursos florales disponibles en esta granja para la temporada dada. " +"Sustituya [ESTACIÓN] por los nombres de las estaciones que coincidan con " +"los de la Tabla de Gremios y la Tabla Biofísica, de modo que haya un " +"campo para cada estación." + +#: src/natcap/invest/pollination.py:152 +msgid "" +"The nesting suitability for the given substrate at this farm. given " +"substrate. Replace [SUBSTRATE] with substrate names matching those in the" +" Guild Table and Biophysical Table, so that there is one field for each " +"substrate." +msgstr "" +"La idoneidad de anidación para el sustrato dado en esta granja. sustrato " +"dado. Sustituir [SUSTRATO] por los nombres de los sustratos que coincidan" +" con los de la tabla de gremios y la tabla biofísica, de modo que haya un" +" campo para cada sustrato." + +#: src/natcap/invest/pollination.py:160 +msgid "The proportion of crop dependent on pollinators." +msgstr "La proporción de cultivos que dependen de los polinizadores." + +#: src/natcap/invest/pollination.py:165 +msgid "" +"The proportion of pollination required on the farm that is provided by " +"managed pollinators." +msgstr "" +"La proporción de la polinización necesaria en la finca que es " +"proporcionada por los polinizadores gestionados." + +#: src/natcap/invest/pollination.py:171 +msgid "" +"Map of farm sites to be analyzed, with pollination data specific to each " +"farm." +msgstr "" +"Mapa de lis sitios de las fincas que se van a analizar, con los datos de" +" polinización específicos de cada finca." + +#: src/natcap/invest/pollination.py:174 +msgid "farms map" +msgstr "mapa de fincas" + +#: src/natcap/invest/pollination.py:180 +msgid "A copy of the input farm polygon vector file with additional fields" +msgstr "" + +#: src/natcap/invest/pollination.py:212 +msgid "" +"Total pollinator abundance across all species per season, clipped to the " +"geometry of the farm vector’s polygons." +msgstr "" + +#: src/natcap/invest/pollination.py:218 +msgid "Abundance of pollinator SPECIES in season SEASON." +msgstr "" + +#: src/natcap/invest/pollination.py:222 +msgid "" +"Index of pollinator SPECIES that could be on a pixel given its arbitrary " +"abundance factor from the table, multiplied by the habitat suitability " +"for that species at that pixel, multiplied by the available floral " +"resources that a pollinator could fly to from that pixel." +msgstr "" + +#: src/natcap/invest/pollination.py:232 +#, fuzzy +msgid "Total pollinator abundance across all species per season." +msgstr "" +"La proporción de la abundancia total de polinizadores que consiste en " +"esta especie/gremio." + +#: src/natcap/invest/pollination.py:238 +msgid "" +"Total pollinator yield index for pixels that overlap farms, including " +"wild and managed pollinators." +msgstr "" + +#: src/natcap/invest/pollination.py:245 +msgid "" +"Pollinator yield index for pixels that overlap farms, for wild " +"pollinators only." +msgstr "" + +#: src/natcap/invest/routedem.py:18 +msgid "Must be between 1 and {maximum}" +msgstr "Debe estar entre 1 y {maximum}" + +#: src/natcap/invest/routedem.py:34 +msgid "Index of the raster band to use, for multi-band rasters." +msgstr "" +"Índice de la banda del ráster que se va a utilizar, para los rásters " +"multibanda." + +#: src/natcap/invest/routedem.py:36 +msgid "band index" +msgstr "índice de bandas" + +#: src/natcap/invest/routedem.py:43 +msgid "" +"All water on a pixel flows into the most downhill of its 8 surrounding " +"pixels" +msgstr "" +"Toda el agua de un píxel fluye hacia el más bajo de sus 8 píxeles " +"circundantes" + +#: src/natcap/invest/routedem.py:48 +msgid "" +"Flow off a pixel is modeled fractionally so that water is split among " +"multiple downslope pixels" +msgstr "" +"El flujo de un píxel se modeliza de forma fraccionada para que el agua se" +" reparta entre varios píxeles pendiente abajo" + +#: src/natcap/invest/routedem.py:52 +msgid "The routing algorithm to use." +msgstr "El algoritmo de enrutamiento a utilizar." + +#: src/natcap/invest/routedem.py:53 +msgid "routing algorithm" +msgstr "algoritmo de enrutamiento" + +#: src/natcap/invest/routedem.py:58 +msgid "Calculate flow direction from the provided DEM." +msgstr "Calcule la dirección del flujo a partir del MDE proporcionado." + +#: src/natcap/invest/routedem.py:59 +msgid "calculate flow direction" +msgstr "cálcular la dirección del flujo" + +#: src/natcap/invest/routedem.py:64 +msgid "Calculate flow accumulation from the flow direction output." +msgstr "" +"Calcular la acumulación de flujo a partir de la salida de la dirección " +"del flujo." + +#: src/natcap/invest/routedem.py:66 +msgid "calculate flow accumulation" +msgstr "cálcular la acumulación de flujo" + +#: src/natcap/invest/routedem.py:71 +msgid "Calculate streams from the flow accumulation output. " +msgstr "Calcular los flujos a partir de la salida de la acumulación de flujos. " + +#: src/natcap/invest/routedem.py:73 +msgid "calculate streams" +msgstr "calcular ls corrientes" + +#: src/natcap/invest/routedem.py:80 +msgid "Required if Calculate Streams is selected." +msgstr "Necesario si se selecciona la opción de calcular corrientes." + +#: src/natcap/invest/routedem.py:85 +msgid "" +"Calculate flow distance from each pixel to a stream as defined in the " +"Calculate Streams output." +msgstr "" +"Calcule la distancia del flujo de cada píxel a una corriente como se " +"define en el resultado de Calcular corrientes." + +#: src/natcap/invest/routedem.py:88 +msgid "calculate distance to stream" +msgstr "calcular la distancia a la corriente" + +#: src/natcap/invest/routedem.py:93 +msgid "Calculate percent slope from the provided DEM." +msgstr "Calcule el porcentaje de pendiente a partir del MDE proporcionado." + +#: src/natcap/invest/routedem.py:94 +msgid "calculate slope" +msgstr "calcular la pendiente" + +#: src/natcap/invest/routedem.py:99 +#, fuzzy +msgid "Calculate the Strahler Stream order." +msgstr "calcular la distancia a la corriente" + +#: src/natcap/invest/routedem.py:100 +#, fuzzy +msgid "calculate strahler stream orders (D8 only)" +msgstr "calcular la distancia a la corriente" + +#: src/natcap/invest/routedem.py:105 +msgid "Determine subwatersheds from the stream order." +msgstr "" + +#: src/natcap/invest/routedem.py:106 +#, fuzzy +msgid "calculate subwatersheds (D8 only)" +msgstr "calcular ls corrientes" + +#: src/natcap/invest/scenario_gen_proximity.py:28 +#, fuzzy +msgid "" +"One or more of \"convert_nearest_to_edge\" or " +"\"convert_farthest_from_edge\" must be selected" +msgstr "" +"Debe seleccionarse una o varias de las opciones " +"\"convertir_más_cercano_al_borde\" o \"convertir_más_alejado_del_borde\"" + +#: src/natcap/invest/scenario_gen_proximity.py:43 +msgid "Base map from which to generate scenarios." +msgstr "Mapa base a partir del cual se generan los escenarios." + +#: src/natcap/invest/scenario_gen_proximity.py:44 +msgid "base LULC map" +msgstr "mapa LULC base" + +#: src/natcap/invest/scenario_gen_proximity.py:48 +msgid "The LULC code to which habitat will be converted." +msgstr "El código LULC al que se convertirá el hábitat." + +#: src/natcap/invest/scenario_gen_proximity.py:49 +msgid "replacement landcover code" +msgstr "código de sustitución de la cubierta vegetal" + +#: src/natcap/invest/scenario_gen_proximity.py:55 +msgid "Maximum area to be converted to agriculture." +msgstr "Superficie máxima a convertir en agricultura." + +#: src/natcap/invest/scenario_gen_proximity.py:56 +msgid "maximum area to convert" +msgstr "superficie máxima a convertir" + +#: src/natcap/invest/scenario_gen_proximity.py:61 +#, fuzzy +msgid "" +"A space-separated list of LULC codes that are used to determine the " +"proximity when referring to 'towards' or 'away' from the base landcover " +"codes" +msgstr "" +"Una lista separada por espacios de los códigos LULC que se utilizan para " +"determinar la proximidad cuando se refiere a \"hacia\" o \"lejos\" de los" +" códigos de la cobertura del suelo base" + +#: src/natcap/invest/scenario_gen_proximity.py:65 +msgid "focal landcover codes" +msgstr "códigos focales de la cubierta vegetal" + +#: src/natcap/invest/scenario_gen_proximity.py:70 +msgid "" +"A space-separated list of LULC codes that can be converted to be " +"converted to agriculture." +msgstr "" +"Una lista separada por espacios de los códigos LULC que pueden ser " +"convertidos a la agricultura." + +#: src/natcap/invest/scenario_gen_proximity.py:73 +msgid "convertible landcover codes" +msgstr "códigos de la cubierta terrestre convertibles" + +#: src/natcap/invest/scenario_gen_proximity.py:79 +msgid "" +"The number of steps that the simulation should take to fragment the " +"habitat of interest in the fragmentation scenario. This parameter is used" +" to divide the conversion simulation into equal subareas of the requested" +" max area. During each sub-step the distance transform is recalculated " +"from the base landcover codes. This can affect the final result if the " +"base types are also convertible types." +msgstr "" +"El número de pasos que debe dar la simulación para fragmentar el hábitat " +"de interés en el escenario de fragmentación. Este parámetro se utiliza " +"para dividir la simulación de conversión en subáreas iguales del área " +"máxima solicitada. Durante cada subpaso, la transformación de la " +"distancia se recalcula a partir de los códigos de la cobertura del suelo " +"base. Esto puede afectar el resultado final si los tipos base son también" +" tipos convertibles." + +#: src/natcap/invest/scenario_gen_proximity.py:87 +msgid "number of conversion steps" +msgstr "número de pasos de conversión" + +#: src/natcap/invest/scenario_gen_proximity.py:92 +msgid "" +"Area over which to run the conversion. Provide this input if change is " +"only desired in a subregion of the Base LULC map." +msgstr "" +"Área sobre la que se va a realizar la conversión. Proporcione este input " +"si solo desea un cambio en una subregión del mapa LULC base." + +#: src/natcap/invest/scenario_gen_proximity.py:98 +msgid "" +"Convert the 'convertible' landcover codes starting at the furthest pixel " +"from the 'focal' land cover areas and working inwards." +msgstr "" +"Convierta los códigos de cobertura del suelo \"convertibles\" empezando " +"por el píxel más alejado de las zonas de cobertura del suelo \"focales\" " +"y trabajando hacia el interior." + +#: src/natcap/invest/scenario_gen_proximity.py:102 +msgid "convert farthest from edge" +msgstr "convertir más lejos del borde" + +#: src/natcap/invest/scenario_gen_proximity.py:106 +msgid "" +"Convert the 'convertible' landcover codes starting at the nearest pixels " +"to the 'focal' land cover areas and working outwards." +msgstr "" +"Convierta los códigos de la cubierta terrestre \"convertible\" empezando " +"por los píxeles más cercanos a las zonas de la cubierta terrestre " +"\"focal\" y trabajando hacia fuera." + +#: src/natcap/invest/scenario_gen_proximity.py:110 +msgid "convert nearest to edge" +msgstr "convertir lo más cercano al borde" + +#: src/natcap/invest/scenario_gen_proximity.py:115 +msgid "Map of the nearest-to-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:119 +msgid "Map of the farthest-from-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:123 +#: src/natcap/invest/scenario_gen_proximity.py:143 +msgid "" +"Table of land cover classes and the amount of each that was converted for" +" the nearest-to-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:166 +msgid "Copy of the LULC raster masked to the AOI extent." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:171 +msgid "" +"Map of the distance from each pixel to the farthest edge of the focal " +"landcover." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:177 +msgid "" +"Map of the distance from each pixel to the nearest edge of the focal " +"landcover." +msgstr "" + +#: src/natcap/invest/spec_utils.py:12 +msgid "workspace" +msgstr "espacio de trabajo" + +#: src/natcap/invest/spec_utils.py:13 +msgid "" +"The folder where all the model's output files will be written. If this " +"folder does not exist, it will be created. If data already exists in the " +"folder, it will be overwritten." +msgstr "" +"La carpeta donde se escribirán todos los archivos resultantes del modelo." +" Si esta carpeta no existe, se creará. Si los datos ya existen en la " +"carpeta, se sobrescribirán." + +#: src/natcap/invest/spec_utils.py:24 +msgid "file suffix" +msgstr "sufijo del archivo" + +#: src/natcap/invest/spec_utils.py:25 +msgid "" +"Suffix that will be appended to all output file names. Useful to " +"differentiate between model runs." +msgstr "" +"Sufijo que se añadirá a todos los nombres de archivos resultantes. Es " +"útil para diferenciar entre las ejecuciones del modelo." + +#: src/natcap/invest/spec_utils.py:34 +#, fuzzy +msgid "taskgraph n_workers parameter" +msgstr "Parámetro n_workers del gráfico de tareas" + +#: src/natcap/invest/spec_utils.py:35 +#, fuzzy +msgid "" +"The n_workers parameter to provide to taskgraph. -1 will cause all jobs " +"to run synchronously. 0 will run all jobs in the same process, but " +"scheduling will take place asynchronously. Any other positive integer " +"will cause that many processes to be spawned to execute tasks." +msgstr "" +"El parámetro n_workers a proporcionar a taskgraph. -1 hará que todos los " +"trabajos se ejecuten de forma sincrónica. 0 hará que todos los trabajos " +"se ejecuten en el mismo proceso, pero la programación tendrá lugar de " +"forma asíncrona. Cualquier otro número entero positivo hará que se " +"generen ese número de procesos para ejecutar las tareas." + +#: src/natcap/invest/spec_utils.py:60 +msgid "area of interest" +msgstr "área de interés" + +#: src/natcap/invest/spec_utils.py:61 +msgid "A map of areas over which to aggregate and summarize the final results." +msgstr "Un mapa de zonas sobre el que agregar y resumir los resultados finales." + +#: src/natcap/invest/spec_utils.py:68 +msgid "" +"Map of land use/land cover codes. Each land use/land cover type must be " +"assigned a unique integer code." +msgstr "" + +#: src/natcap/invest/spec_utils.py:71 +msgid "land use/land cover" +msgstr "uso del suelo/cobertura del suelo" + +#: src/natcap/invest/spec_utils.py:81 +msgid "Map of elevation above sea level." +msgstr "Mapa de elevación sobre el nivel del mar." + +#: src/natcap/invest/spec_utils.py:82 +msgid "digital elevation model" +msgstr "modelo digital de elevación" + +#: src/natcap/invest/spec_utils.py:92 +msgid "Map of average annual precipitation." +msgstr "Mapa de la precipitación media anual." + +#: src/natcap/invest/spec_utils.py:93 +msgid "precipitation" +msgstr "precipitación" + +#: src/natcap/invest/spec_utils.py:96 +msgid "evapotranspiration" +msgstr "evapotranspiración" + +#: src/natcap/invest/spec_utils.py:104 +msgid "Map of evapotranspiration values." +msgstr "Mapa de valores de evapotranspiración." + +#: src/natcap/invest/spec_utils.py:109 +msgid "" +"Map of soil hydrologic groups. Pixels may have values 1, 2, 3, or 4, " +"corresponding to soil hydrologic groups A, B, C, or D, respectively." +msgstr "" +"Mapa de los grupos hidrológicos del suelo. Los píxeles pueden tener los " +"valores 1, 2, 3 o 4, correspondientes a los grupos hidrológicos de suelo " +"A, B, C o D, respectivamente." + +#: src/natcap/invest/spec_utils.py:112 +msgid "soil hydrologic group" +msgstr "grupo hidrológico del suelo" + +#: src/natcap/invest/spec_utils.py:118 +msgid "" +"The number of upslope pixels that must flow into a pixel before it is " +"classified as a stream." +msgstr "" +"El número de píxeles pendiente arriba que deben fluir en un píxel antes " +"de que se clasifique como una corriente." + +#: src/natcap/invest/spec_utils.py:121 +msgid "threshold flow accumulation" +msgstr "umbral de acumulación de flujo" + +#: src/natcap/invest/spec_utils.py:125 +#: src/natcap/invest/urban_flood_risk_mitigation.py:64 +#, fuzzy +msgid "LULC codes from the LULC raster. Each code must be a unique integer." +msgstr "Código LULC del ráster LULC." + +#: src/natcap/invest/spec_utils.py:141 +msgid "Map of elevation after any pits are filled" +msgstr "" + +#: src/natcap/invest/spec_utils.py:148 +#, fuzzy +msgid "Map of flow accumulation" +msgstr "umbral de acumulación de flujo" + +#: src/natcap/invest/spec_utils.py:155 +msgid "" +"MFD flow direction. Note: the pixel values should not be interpreted " +"directly. Each 32-bit number consists of 8 4-bit numbers. Each 4-bit " +"number represents the proportion of flow into one of the eight " +"neighboring pixels." +msgstr "" + +#: src/natcap/invest/spec_utils.py:164 +#, fuzzy +msgid "D8 flow direction." +msgstr "cálcular la dirección del flujo" + +#: src/natcap/invest/spec_utils.py:169 +msgid "" +"Percent slope, calculated from the pit-filled DEM. 100 is equivalent to a" +" 45 degree slope." +msgstr "" + +#: src/natcap/invest/spec_utils.py:222 +#, fuzzy +msgid "number of pixels" +msgstr "número de turbinas" + +#: src/natcap/invest/spec_utils.py:231 +msgid "unitless" +msgstr "" + +#: src/natcap/invest/spec_utils.py:251 +msgid "currency units" +msgstr "" + +#: src/natcap/invest/spec_utils.py:306 +msgid "required" +msgstr "requerido" + +#: src/natcap/invest/spec_utils.py:308 +msgid "optional" +msgstr "opcional" + +#: src/natcap/invest/spec_utils.py:311 +msgid "conditionally required" +msgstr "condicionalmente requerido" + +#: src/natcap/invest/spec_utils.py:341 +msgid "read" +msgstr "leer" + +#: src/natcap/invest/spec_utils.py:343 +msgid "write" +msgstr "escribir" + +#: src/natcap/invest/spec_utils.py:345 +msgid "execute" +msgstr "ejecutar" + +#: src/natcap/invest/spec_utils.py:422 +msgid "true/false" +msgstr "verdadero/falso" + +#: src/natcap/invest/spec_utils.py:423 +msgid "CSV" +msgstr "CSV" + +#: src/natcap/invest/spec_utils.py:424 +msgid "directory" +msgstr "directorio" + +#: src/natcap/invest/spec_utils.py:425 +msgid "file" +msgstr "archivo" + +#: src/natcap/invest/spec_utils.py:426 +msgid "text" +msgstr "texto" + +#: src/natcap/invest/spec_utils.py:427 +msgid "integer" +msgstr "entero" + +#: src/natcap/invest/spec_utils.py:428 +msgid "number" +msgstr "número" + +#: src/natcap/invest/spec_utils.py:429 +msgid "option" +msgstr "opción" + +#: src/natcap/invest/spec_utils.py:430 +msgid "percent" +msgstr "porcentaje" + +#: src/natcap/invest/spec_utils.py:431 +msgid "raster" +msgstr "ráster" + +#: src/natcap/invest/spec_utils.py:432 +msgid "ratio" +msgstr "proporción" + +#: src/natcap/invest/spec_utils.py:433 +msgid "vector" +msgstr "vector" + +#: src/natcap/invest/spec_utils.py:504 +msgid "units" +msgstr "" + +#: src/natcap/invest/spec_utils.py:533 src/natcap/invest/spec_utils.py:537 +msgid "Options:" +msgstr "Opciones:" + +#: src/natcap/invest/spec_utils.py:541 +msgid " Please see the sample data table for details on the format." +msgstr " Consulte la tabla de datos de muestra para conocer el formato." + +#: src/natcap/invest/stormwater.py:56 +msgid "" +"Event mean concentration of the pollutant in stormwater. You may include " +"any number of these columns for different pollutants, or none at all." +msgstr "" +"Concentración media del contaminante del evento en las aguas pluviales. " +"Puede incluir cualquier número de estas columnas para diferentes " +"contaminantes, o ninguna." + +#: src/natcap/invest/stormwater.py:65 +msgid "Stormwater runoff coefficient for soil group" +msgstr "Coeficiente de escorrentía de aguas pluviales para el grupo de suelos" + +#: src/natcap/invest/stormwater.py:74 +msgid "Stormwater percolation coefficient for soil group" +msgstr "Coeficiente de percolación de las aguas pluviales para el grupo de suelos" + +#: src/natcap/invest/stormwater.py:84 +#, fuzzy +msgid "" +"Enter 1 if the LULC class is a connected impervious surface, 0 if not. " +"This column is only used if the 'adjust retention ratios' option is " +"selected. If 'adjust retention ratios' is selected and this column " +"exists, the adjustment algorithm takes into account the LULC as well as " +"road centerlines. If this column does not exist, only the road " +"centerlines are used." +msgstr "" +"Introduzca 1 si la clase LULC es una superficie impermeable conectada, 0 " +"si no lo es. Esta columna solo se utiliza si se selecciona la opción " +"\"ajustar los coeficientes de retención\". Si se selecciona la opción " +"\"ajustar relaciones de retención\" y esta columna existe, el algoritmo " +"de ajuste tiene en cuenta la LULC y las líneas centrales de las " +"carreteras. Si esta columna no existe, solo se utilizan las líneas " +"centrales de las carreteras." + +#: src/natcap/invest/stormwater.py:95 +msgid "" +"Table mapping each LULC code found in the LULC raster to biophysical data" +" about that LULC class. If you provide the percolation coefficient column" +" (PE_[X]) for any soil group, you must provide it for all four soil " +"groups." +msgstr "" +"Tabla que asigna cada código LULC encontrado en el ráster LULC a los " +"datos biofísicos sobre esa clase LULC. Si proporciona la columna del " +"coeficiente de percolación (PE_[X]) para cualquier grupo de suelos, debe " +"proporcionarla para los cuatro grupos de suelos." + +#: src/natcap/invest/stormwater.py:100 +msgid "Biophysical table" +msgstr "Tabla biofísica" + +#: src/natcap/invest/stormwater.py:104 +#, fuzzy +msgid "" +"If true, adjust retention ratios. The adjustment algorithm accounts for " +"drainage effects of nearby impervious surfaces which are directly " +"connected to artifical urban drainage channels (typically roads, parking " +"lots, etc.) Connected impervious surfaces are indicated by the " +"is_connected columnin the biophysical table and/or the road centerlines " +"vector." +msgstr "" +"Si es cierto, ajusta los coeficientes de retención. El algoritmo de " +"ajuste tiene en cuenta los efectos del drenaje de las superficies " +"impermeables cercanas que están directamente conectadas a los canales de " +"drenaje urbano artificiales (normalmente carreteras, estacionamientos, " +"etc.). Las superficies impermeables conectadas se indican mediante la " +"columna is_connected en la tabla biofísica y/o el vector de líneas " +"centrales de carreteras." + +#: src/natcap/invest/stormwater.py:111 +msgid "Adjust retention ratios" +msgstr "Ajustar las tasas de retención" + +#: src/natcap/invest/stormwater.py:117 +msgid "" +"Radius around each pixel to adjust retention ratios. Measured in raster " +"coordinate system units. For the adjustment algorithm, a pixel is 'near' " +"a connected impervious surface if its centerpoint is within this radius " +"of connected-impervious LULC and/or a road centerline." +msgstr "" +"Radio alrededor de cada píxel para ajustar las relaciones de retención. " +"Medido en unidades del sistema de coordenadas raster. Para el algoritmo " +"de ajuste, un píxel está \"cerca\" de una superficie impermeable " +"conectada si su punto central está dentro de este radio de LULC " +"impermeable conectada y/o una línea central de carretera." + +#: src/natcap/invest/stormwater.py:123 +msgid "Retention radius" +msgstr "Radio de retención" + +#: src/natcap/invest/stormwater.py:130 +msgid "Map of road centerlines" +msgstr "Mapa de líneas centrales de carreteras" + +#: src/natcap/invest/stormwater.py:131 +msgid "Road centerlines" +msgstr "Líneas centrales de la carretera" + +#: src/natcap/invest/stormwater.py:136 +msgid "" +"Areas over which to aggregate results (typically watersheds or " +"sewersheds). The aggregated data are: average retention ratio and total " +"retention volume; average percolation ratio and total percolation volume " +"if percolation data was provided; total retention value if replacement " +"cost was provided; and total avoided pollutant load for each pollutant " +"provided." +msgstr "" +"Zonas sobre las que se van a agregar los resultados (normalmente cuencas " +"hidrográficas o de alcantarillado). Los datos agregados son: ratio de " +"retención media y volumen de retención total; ratio de percolación media " +"y volumen de percolación total si se facilitan datos de percolación; " +"valor de retención total si se facilita el costo de reposición; y carga " +"contaminante total evitada para cada contaminante facilitado." + +#: src/natcap/invest/stormwater.py:149 +msgid "Replacement cost of stormwater retention devices" +msgstr "Costo de sustitución de los dispositivos de retención de aguas pluviales" + +#: src/natcap/invest/stormwater.py:150 +msgid "Replacement cost" +msgstr "Costo de sustitución" + +#: src/natcap/invest/stormwater.py:155 +msgid "" +"Map of the stormwater retention ratio, derived from the LULC raster and " +"biophysical table RC_x columns." +msgstr "" + +#: src/natcap/invest/stormwater.py:162 +msgid "" +"Map of the adjusted retention ratio, calculated according to equation " +"(124) from the ‘retention_ratio, ratio_average, near_road’, and " +"‘near_impervious_lulc’ intermediate outputs." +msgstr "" + +#: src/natcap/invest/stormwater.py:169 +#, fuzzy +msgid "Map of retention volume." +msgstr "Mapa de valores de evapotranspiración." + +#: src/natcap/invest/stormwater.py:177 +msgid "" +"Map of percolation ratio derived by cross-referencing the LULC and soil " +"group rasters with the biophysical table." +msgstr "" + +#: src/natcap/invest/stormwater.py:184 +msgid "Map of percolation (potential aquifer recharge) volume." +msgstr "" + +#: src/natcap/invest/stormwater.py:191 +msgid "" +"Map of the stormwater runoff ratio. This is the inverse of " +"‘retention_ratio.tif’" +msgstr "" + +#: src/natcap/invest/stormwater.py:197 +msgid "Map of runoff volume." +msgstr "" + +#: src/natcap/invest/stormwater.py:205 +msgid "Map of the value of water retained." +msgstr "" + +#: src/natcap/invest/stormwater.py:213 +msgid "" +"Map of aggregate data. This is identical to the aggregate areas input " +"vector, but each polygon is given additional fields with the aggregate " +"data." +msgstr "" + +#: src/natcap/invest/stormwater.py:221 +msgid "Average retention ratio over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:226 +msgid "Total retention volume over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:230 +#, fuzzy +msgid "Average runoff coefficient over this polygon" +msgstr "Coeficiente de escorrentía de aguas pluviales para el grupo de suelos" + +#: src/natcap/invest/stormwater.py:235 +msgid "Total runoff volume over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:239 +msgid "Average percolation (recharge) ratio over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:244 +msgid "Total volume of potential aquifer recharge over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:249 +msgid "Total avoided (retained) amount of pollutant over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:254 +msgid "Total amount of pollutant in runoff over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:260 +msgid "Total value of the retained volume of water over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:270 +msgid "" +"Copy of the soil group raster input, cropped to the intersection of the " +"three raster inputs." +msgstr "" + +#: src/natcap/invest/stormwater.py:276 +msgid "" +"Copy of the soil group raster input, aligned to the LULC raster and " +"cropped to the intersection of the three raster inputs." +msgstr "" + +#: src/natcap/invest/stormwater.py:283 +msgid "" +"Copy of the precipitation raster input, aligned to the LULC raster and " +"cropped to the intersection of the three raster inputs." +msgstr "" + +#: src/natcap/invest/stormwater.py:295 +msgid "" +"Copy of the road centerlines vector input, reprojected to the LULC raster" +" projection." +msgstr "" + +#: src/natcap/invest/stormwater.py:303 +msgid "" +"A rasterized version of the reprojected centerlines vector, where 1 means" +" the pixel is a road and 0 means it isn’t." +msgstr "" + +#: src/natcap/invest/stormwater.py:310 +msgid "" +"A binary raster derived from the LULC raster and biophysical table " +"is_connected column, where 1 means the pixel has a directly-connected " +"impervious LULC type, and 0 means it does not." +msgstr "" + +#: src/natcap/invest/stormwater.py:318 +msgid "" +"A raster derived from the rasterized centerlines map, where each pixel’s " +"value is its minimum distance to a road pixel (measured centerpoint-to-" +"centerpoint)." +msgstr "" + +#: src/natcap/invest/stormwater.py:328 +msgid "" +"A raster derived from the is_connected_lulc map, where each pixel’s value" +" is its minimum distance to a connected impervious LULC pixel (measured " +"centerpoint-to-centerpoint)." +msgstr "" + +#: src/natcap/invest/stormwater.py:339 +msgid "" +"A binary raster derived from the road_distance map, where 1 means the " +"pixel is within the retention radius of a road pixel, and 0 means it " +"isn’t." +msgstr "" + +#: src/natcap/invest/stormwater.py:346 +msgid "" +"A binary raster derived from the connected_lulc_distance map, where 1 " +"means the pixel is within the retention radius of a connected impervious " +"LULC pixel, and 0 means it isn’t." +msgstr "" + +#: src/natcap/invest/stormwater.py:354 +msgid "" +"A binary raster representing the search kernel that is convolved with the" +" retention_ratio raster to calculate the averaged retention ratio within " +"the retention radius of each pixel." +msgstr "" + +#: src/natcap/invest/stormwater.py:362 +msgid "" +"A raster where each pixel’s value is the average of its neighborhood of " +"pixels in the retention_ratio map, calculated by convolving the search " +"kernel with the retention ratio raster." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:49 +msgid "" +"Map of LULC for the area of interest. All values in this raster must have" +" corresponding entries in the Biophysical Table." +msgstr "" +"Mapa de LULC para el área de interés. Todos los valores de este ráster " +"deben tener los inputs correspondientes en la Tabla Biofísica." + +#: src/natcap/invest/urban_cooling_model.py:68 +msgid "" +"Enter 1 to indicate that the LULC is considered a green area. Enter 0 to " +"indicate that the LULC is not considered a green area." +msgstr "" +"Introduzca 1 para indicar que el LULC se considera una zona verde. " +"Introduzca 0 para indicar que el LULC no se considera una zona verde." + +#: src/natcap/invest/urban_cooling_model.py:75 +msgid "" +"The proportion of area in this LULC class that is covered by tree canopy " +"at least 2 meters high. Required if the 'factors' option is selected for " +"the Cooling Capacity Calculation Method." +msgstr "" +"Proporción de la superficie de esta clase de LULC que está cubierta por " +"un dosel de árboles de al menos 2 metros de altura. Necesario si se " +"selecciona la opción \"factores\" para el método de cálculo de la " +"capacidad de enfriamiento." + +#: src/natcap/invest/urban_cooling_model.py:83 +msgid "" +"The proportion of solar radiation that is directly reflected by this LULC" +" class. Required if the 'factors' option is selected for the Cooling " +"Capacity Calculation Method." +msgstr "" +"Proporción de la radiación solar que refleja directamente esta clase de " +"LULC. Necesaria si se selecciona la opción \"factores\" para el método de" +" cálculo de la capacidad de enfriamiento." + +#: src/natcap/invest/urban_cooling_model.py:91 +msgid "" +"The ratio of building floor area to footprint area, with all values in " +"this column normalized between 0 and 1. Required if the 'intensity' " +"option is selected for the Cooling Capacity Calculation Method." +msgstr "" +"La relación entre la superficie de piso de la construcción y la " +"superficie de la huella, con todos los valores de esta columna " +"normalizados entre 0 y 1. Necesaria si se selecciona la opción " +"\"intensidad\" para el método de cálculo de la capacidad de enfriamiento." + +#: src/natcap/invest/urban_cooling_model.py:98 +msgid "" +"A table mapping each LULC code to biophysical data for that LULC class. " +"All values in the LULC raster must have corresponding entries in this " +"table." +msgstr "" +"Una tabla que asigna cada código LULC a los datos biofísicos de esa clase" +" LULC. Todos los valores del ráster LULC deben tener los inputs " +"correspondientes en esta tabla." + +#: src/natcap/invest/urban_cooling_model.py:107 +msgid "maximum cooling distance" +msgstr "distancia máxima de enfriamiento" + +#: src/natcap/invest/urban_cooling_model.py:108 +msgid "" +"Distance over which green areas larger than 2 hectares have a cooling " +"effect." +msgstr "" +"Distancia en la que las zonas verdes de más de 2 hectáreas tienen un " +"efecto refrigerante." + +#: src/natcap/invest/urban_cooling_model.py:116 +msgid "air blending distance" +msgstr "distancia de mezcla de aire" + +#: src/natcap/invest/urban_cooling_model.py:117 +msgid "Radius over which to average air temperatures to account for air mixing." +msgstr "" +"Radio sobre el que se promedian las temperaturas del aire para considerar" +" la mezcla del aire." + +#: src/natcap/invest/urban_cooling_model.py:122 +msgid "reference air temperature" +msgstr "temperatura del aire de referencia" + +#: src/natcap/invest/urban_cooling_model.py:125 +msgid "" +"Air temperature in a rural reference area where the urban heat island " +"effect is not observed." +msgstr "" +"Temperatura del aire en una zona rural de referencia en la que no se " +"observa el efecto de isla de calor urbana." + +#: src/natcap/invest/urban_cooling_model.py:130 +msgid "UHI effect" +msgstr "Efecto isla de calor urbana" + +#: src/natcap/invest/urban_cooling_model.py:133 +msgid "" +"The magnitude of the urban heat island effect, i.e., the difference " +"between the rural reference temperature and the maximum temperature " +"observed in the city." +msgstr "" +"La magnitud del efecto isla de calor urbana, es decir, la diferencia " +"entre la temperatura de referencia rural y la temperatura máxima " +"observada en la ciudad." + +#: src/natcap/invest/urban_cooling_model.py:139 +msgid "run energy savings valuation" +msgstr "ejecutar la valoración del ahorro de energía" + +#: src/natcap/invest/urban_cooling_model.py:141 +msgid "Run the energy savings valuation model." +msgstr "Ejecutar el modelo de valoración del ahorro energético." + +#: src/natcap/invest/urban_cooling_model.py:144 +msgid "run work productivity valuation" +msgstr "ejecutar la valoración de la productividad del trabajo" + +#: src/natcap/invest/urban_cooling_model.py:146 +msgid "Run the work productivity valuation model." +msgstr "Ejecutar el modelo de valoración de la productividad del trabajo." + +#: src/natcap/invest/urban_cooling_model.py:149 +msgid "average relative humidity" +msgstr "humedad relativa media" + +#: src/natcap/invest/urban_cooling_model.py:152 +msgid "" +"The average relative humidity over the time period of interest. Required " +"if Run Work Productivity Valuation is selected." +msgstr "" +"La humedad relativa media durante el período de tiempo de interés. " +"Requerida si se selecciona la opción de ejecutar valoración de la " +"productividad del trabajo." + +#: src/natcap/invest/urban_cooling_model.py:158 +msgid "buildings" +msgstr "construcciones" + +#: src/natcap/invest/urban_cooling_model.py:163 +msgid "" +"Code indicating the building type. These codes must match those in the " +"Energy Consumption Table." +msgstr "" +"Código que indica el tipo de construcción. Estos códigos deben coincidir " +"con los de la tabla de consumo energético." + +#: src/natcap/invest/urban_cooling_model.py:168 +msgid "" +"A map of built infrastructure footprints. Required if Run Energy Savings " +"Valuation is selected." +msgstr "" +"Un mapa de las huellas de las infraestructuras construidas. Se necesita " +"si se selecciona la opción de ejecutar valoración del ahorro de energía." + +#: src/natcap/invest/urban_cooling_model.py:173 +msgid "energy consumption table" +msgstr "tabla de consumo de energía" + +#: src/natcap/invest/urban_cooling_model.py:179 +#, fuzzy +msgid "Building type codes matching those in the Buildings vector." +msgstr "" +"Códigos de tipo de construcción que coinciden con los del vector " +"Buildings." + +#: src/natcap/invest/urban_cooling_model.py:186 +msgid "Energy consumption by footprint area for this building type." +msgstr "" +"Consumo de energía por superficie de la huella para este tipo de " +"construcción." + +#: src/natcap/invest/urban_cooling_model.py:194 +msgid "" +"The cost of electricity for this building type. If this column is " +"provided, the energy savings outputs will be in the this currency unit " +"rather than kWh." +msgstr "" +"El costo de la electricidad para este tipo de construcción. Si se " +"proporciona esta columna, los resultados de ahorro de energía estarán en " +"esta unidad monetaria en lugar de en kWh." + +#: src/natcap/invest/urban_cooling_model.py:202 +msgid "" +"A table of energy consumption data for each building type. Required if " +"Run Energy Savings Valuation is selected." +msgstr "" +"Una tabla de datos de consumo de energía para cada tipo de construcción. " +"Se necesita si se selecciona la opción de ejecutar la valoración del " +"ahorro de energía." + +#: src/natcap/invest/urban_cooling_model.py:207 +msgid "cooling capacity calculation method" +msgstr "método de cálculo de la capacidad de enfriamiento" + +#: src/natcap/invest/urban_cooling_model.py:211 +msgid "factors" +msgstr "factores" + +#: src/natcap/invest/urban_cooling_model.py:212 +#, fuzzy +msgid "" +"Use the weighted shade, albedo, and ETI factors as a temperature " +"predictor (for daytime temperatures)." +msgstr "" +"Utilizar los factores ponderados de sombra, albedo e IET como predictor " +"de temperatura (para las temperaturas diurnas)." + +#: src/natcap/invest/urban_cooling_model.py:216 +msgid "intensity" +msgstr "intensidad" + +#: src/natcap/invest/urban_cooling_model.py:217 +msgid "" +"Use building intensity as a temperature predictor (for nighttime " +"temperatures)." +msgstr "" +"Utilizar la intensidad de construcción como predictor de la temperatura " +"(para las temperaturas nocturnas)." + +#: src/natcap/invest/urban_cooling_model.py:221 +msgid "The air temperature predictor method to use." +msgstr "El método de predicción de la temperatura del aire a utilizar." + +#: src/natcap/invest/urban_cooling_model.py:224 +msgid "shade weight" +msgstr "peso de la sombra" + +#: src/natcap/invest/urban_cooling_model.py:227 +msgid "" +"The relative weight to apply to shade when calculating the cooling " +"capacity index. If not provided, defaults to 0.6." +msgstr "" +"La ponderación relativa que se aplica a la sombra cuando se calcula el " +"índice de capacidad de enfriamiento. Si no se proporciona, el valor " +"predeterminado es 0.6." + +#: src/natcap/invest/urban_cooling_model.py:232 +msgid "albedo weight" +msgstr "poneración del albedo" + +#: src/natcap/invest/urban_cooling_model.py:235 +msgid "" +"The relative weight to apply to albedo when calculating the cooling " +"capacity index. If not provided, defaults to 0.2." +msgstr "" +"La ponderación relativa que se aplica al albedo cuando se calcula el " +"índice de capacidad de enfriamiento. Si no se proporciona, el valor " +"predeterminado es 0.2." + +#: src/natcap/invest/urban_cooling_model.py:240 +msgid "evapotranspiration weight" +msgstr "ponderación de la evapotranspiración" + +#: src/natcap/invest/urban_cooling_model.py:243 +msgid "" +"The relative weight to apply to ETI when calculating the cooling capacity" +" index. If not provided, defaults to 0.2." +msgstr "" +"La ponderación relativa que se aplicará al IET cuando se calcule el " +"índice de capacidad de enfriamiento. Si no se proporciona, el valor " +"predeterminado es 0.2." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:44 +msgid "Depth of rainfall for the design storm of interest." +msgstr "Profundidad de las precipitaciones para la tormenta de diseño de interés." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:45 +msgid "rainfall depth" +msgstr "profundidad de la precipitación" + +#: src/natcap/invest/urban_flood_risk_mitigation.py:50 +msgid "" +"Map of LULC. All values in this raster must have corresponding entries in" +" the Biophysical Table." +msgstr "" +"Mapa de LULC. Todos los valores de este ráster deben tener los inputs " +"correspondientes en la tabla biofísica." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:68 +msgid "The curve number value for this LULC type in the soil group code" +msgstr "" +"El valor del número de curva para este tipo de LULC en el código de grupo" +" de suelos" + +#: src/natcap/invest/urban_flood_risk_mitigation.py:73 +msgid "" +"Table of curve number data for each LULC class. All LULC codes in the " +"LULC raster must have corresponding entries in this table for each soil " +"group." +msgstr "" +"Tabla de datos del número de curva para cada clase LULC. Todos los " +"códigos LULC en el raster LULC deben tener los inputs correspondientes en" +" esta tabla para cada grupo de suelos." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:84 +#, fuzzy +msgid "" +"Code indicating the building type. These codes must match those in the " +"Damage Loss Table." +msgstr "" +"Código que indica el tipo de construcción. Estos códigos deben coincidir " +"con los de la Tabla de Pérdidas por Daños." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:90 +msgid "Map of building footprints." +msgstr "Mapa de las huellas de las construcciones." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:91 +msgid "built infrastructure" +msgstr "infraestructura construida" + +#: src/natcap/invest/urban_flood_risk_mitigation.py:99 +msgid "Building type code." +msgstr "Código de tipo de construcción." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:103 +msgid "Potential damage loss for this building type." +msgstr "Pérdida potencial de daños para este tipo de construcción." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:106 +msgid "" +"Table of potential damage loss data for each building type. All values in" +" the Built Infrastructure vector 'type' field must have corresponding " +"entries in this table. Required if the Built Infrastructure vector is " +"provided." +msgstr "" +"Tabla de datos de pérdidas de daños potenciales para cada tipo de " +"construcción. Todos los valores del campo \"tipo\" del vector " +"Infraestructura construida deben tener los inputs correspondientes en " +"esta tabla. Obligatorio si se proporciona el vector Infraestructura " +"construida." + +#: src/natcap/invest/urban_flood_risk_mitigation.py:111 +msgid "damage loss table" +msgstr "tabla de pérdidas por daños" + +#: src/natcap/invest/urban_nature_access.py:130 +msgid "" +"The proportion of the population within each administrative unit " +"belonging to the identified population group (POP_GROUP). At least one " +"column with the prefix 'pop_' is required when aggregating output by " +"population groups." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:139 +msgid "" +"A vector representing administrative units. Polygons representing " +"administrative units should not overlap. Overlapping administrative " +"geometries may cause unexpected results and for this reason should not " +"overlap." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:151 +msgid "" +"The amount of urban nature that each resident should have access to. This" +" is often defined by local urban planning documents." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:163 +msgid "" +"All pixels within the search radius contribute equally to an urban nature" +" pixel." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:169 +msgid "" +"Contributions to an urban nature pixel decrease exponentially, where " +"\"weight = e^(-pixel_dist / search_radius)\"" +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:176 +msgid "" +"Contributions to an urban nature pixel decrease according to a normal " +"(\"gaussian\") distribution with a sigma of 3." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:183 +msgid "" +"Contributions to an urban nature pixel decrease faster as distances " +"approach the search radius. Weights are calculated by \"weight = 0.75 * " +"(1-(pixel_dist / search_radius)^2)\"" +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:210 +#, fuzzy +msgid "The type of search radius to use." +msgstr "El tipo de valor AME en esta fila." + +#: src/natcap/invest/urban_nature_access.py:216 +msgid "The search radius is the same for all types of urban nature." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:222 +msgid "" +"The search radius is defined for each distinct urban nature LULC " +"classification." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:228 +msgid "The search radius is defined for each distinct population group." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:238 +msgid "" +"Whether to aggregate statistics by population group within each " +"administrative unit. If selected, population groups will be read from the" +" fields of the user-defined administrative boundaries vector. This option" +" is implied if the search radii are defined by population groups." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:252 +msgid "" +"The search radius to use when running the model under a uniform search " +"radius. Required when running the model with a uniform search radius. " +"Units are in meters." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:266 +msgid "" +"The name of the population group. Names must match the names defined in " +"the administrative boundaries vector." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:276 +msgid "" +"The search radius in meters to use for this population group. Values " +"must be >= 0." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:282 +msgid "" +"A table associating population groups with the distance in meters that " +"members of the population group will, on average, travel to find urban " +"nature. Required when running the model with search radii defined per " +"population group." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:418 +msgid "" +"Positive pixel values indicate an oversupply of urban nature for the " +"population group POP_GROUP relative to the stated urban nature demand. " +"Negative values indicate an undersupply of urban nature for the " +"population group POP_GROUP relative to the stated urban nature demand." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:432 +msgid "" +"The area of greenspace available within the defined radius, weighted by " +"the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:442 +msgid "" +"The area of greenspace available within the radius associated with urban " +"nature class LUCODE, weighted by the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:453 +msgid "" +"The area of greenspace available within the radius associated with group " +"POP_GROUP, weighted by the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:467 +msgid "" +"A copy of the user's land use land cover raster. If the user-supplied " +"LULC has non-square pixels, they will be resampled to square pixels in " +"this raster." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:475 +msgid "" +"The user's population raster, aligned to the same resolution and " +"dimensions as the aligned LULC." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:481 +msgid "The population experiencing an urban nature deficit." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:487 +msgid "The population experiencing an urban nature surplus." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:495 +msgid "" +"A sum of the population within the given search radius SEARCH_RADIUS, " +"weighted by the user's decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:505 +msgid "The area of urban nature (in square meters) represented in each pixel." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:514 +msgid "The calculated urban nature/population ratio." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:523 +msgid "" +"Pixel values represent the ares of urban nature (in square meters) " +"represented in each pixel for the urban nature class represented by the " +"land use land cover code LUCODE." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:533 +msgid "" +"The urban nature supplied to populations due to the land use land cover " +"code LUCODE" +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:541 +msgid "" +"The calculated urban nature/population ratio for the urban nature class " +"represented by the land use land cover code LUCODE." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:552 +msgid "" +"Each pixel represents the population of a pixel belonging to the " +"population in the population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:561 +msgid "" +"Each pixel represents the proportion of the total population that belongs" +" to the population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:570 +msgid "" +"Each pixel represents the total number of people within the search radius" +" for the population group POP_GROUP, weighted by the user's selection of " +"decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:580 +msgid "The total population, weighted by the appropriate decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:588 +msgid "The urban nature supply per capita to population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:596 +msgid "" +"The population in population group POP_GROUP that are experiencing an " +"urban nature deficit." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:604 +msgid "" +"The population in population group POP_GROUP that are experiencing an " +"urban nature surplus." +msgstr "" + +#: src/natcap/invest/validation.py:33 +#, fuzzy +msgid "Key is missing from the args dict" +msgstr "Falta la clave en el dictado de args" + +#: src/natcap/invest/validation.py:34 +msgid "Input is required but has no value" +msgstr "El input es necesario pero no tiene valor" + +#: src/natcap/invest/validation.py:35 +msgid "Expected the {header} \"{header_name}\" but did not find it" +msgstr "Esperaba el {header} \"{header_name}\" pero no lo encontró" + +#: src/natcap/invest/validation.py:37 +#, fuzzy +msgid "" +"Expected to find at least one {header} matching the pattern " +"\"{header_name}\" but found none" +msgstr "Esperaba el {header} \"{header_name}\" pero no lo encontró" + +#: src/natcap/invest/validation.py:40 +msgid "" +"Expected the {header} \"{header_name}\" only once but found it {number} " +"times" +msgstr "" +"Esperaba el {header} \"{header_name}\" solo una vez pero lo encontró " +"{number} veces" + +#: src/natcap/invest/validation.py:43 +#, fuzzy +msgid "Value \"{value}\" could not be interpreted as a number" +msgstr "El valor \"{value}\" no pudo ser interpretado como un número" + +#: src/natcap/invest/validation.py:45 +#, fuzzy +msgid "" +"Layer must be projected in this unit: \"{unit_a}\" but found this unit: " +"\"{unit_b}\"" +msgstr "" +"La capa debe ser proyectada en esta unidad: \"{unit_a}\" pero se ha " +"encontrado esta unidad: \"{unit_b}\"" + +#: src/natcap/invest/validation.py:48 +msgid "An unexpected error occurred in validation" +msgstr "Se ha producido un error inesperado en la validación" + +#: src/natcap/invest/validation.py:49 +msgid "Directory not found" +msgstr "Directorio no encontrado" + +#: src/natcap/invest/validation.py:50 +msgid "Path must be a directory" +msgstr "La ruta debe ser un directorio" + +#: src/natcap/invest/validation.py:51 +msgid "File not found" +msgstr "Archivo no encontrado" + +#: src/natcap/invest/validation.py:52 +msgid "Dataset must have a valid projection." +msgstr "El conjunto de datos debe tener una proyección válida." + +#: src/natcap/invest/validation.py:53 +msgid "Dataset must be projected in linear units." +msgstr "El conjunto de datos debe proyectarse en unidades lineales." + +#: src/natcap/invest/validation.py:54 +msgid "File could not be opened as a GDAL raster" +msgstr "No se ha podido abrir el archivo como un ráster GDAL" + +#: src/natcap/invest/validation.py:55 +msgid "File found to be an overview \".ovr\" file." +msgstr "Se ha encontrado que el archivo es un archivo de resumen \".ovr\"." + +#: src/natcap/invest/validation.py:56 +msgid "File could not be opened as a GDAL vector" +msgstr "No se ha podido abrir el archivo como vector GDAL" + +#: src/natcap/invest/validation.py:57 +#, fuzzy +msgid "Value did not match expected pattern {regexp}" +msgstr "El valor no coincide con el patrón esperado {regexp}" + +#: src/natcap/invest/validation.py:59 +#, fuzzy +msgid "Value must be one of: {option_list}" +msgstr "El valor debe ser uno de: {option_list}" + +#: src/natcap/invest/validation.py:60 +#, fuzzy +msgid "Value does not meet condition {condition}" +msgstr "El valor no cumple la condición {condition}" + +#: src/natcap/invest/validation.py:61 +#, fuzzy +msgid "Value {value} is not in the range {range}" +msgstr "El valor {value} no está en el rango {range}" + +#: src/natcap/invest/validation.py:62 +#, fuzzy +msgid "Value \"{value}\" does not represent an integer" +msgstr "El valor \"{value}\" no representa un entero" + +#: src/natcap/invest/validation.py:63 +#, fuzzy +msgid "Value must be either True or False, not {value}" +msgstr "El valor debe ser Verdadero o Falso, no {value}" + +#: src/natcap/invest/validation.py:64 +#, fuzzy +msgid "Spatial file {filepath} has no projection" +msgstr "El archivo espacial {filepath} no tiene proyección" + +#: src/natcap/invest/validation.py:65 +msgid "" +"Not all of the spatial layers overlap each other. All bounding boxes must" +" intersect: {bboxes}" +msgstr "" + +#: src/natcap/invest/validation.py:68 +#, fuzzy +msgid "You must have {permission} access to this file" +msgstr "Debe tener acceso {permission} a este archivo" + +#: src/natcap/invest/validation.py:70 +msgid "Geometry type must be one of {allowed}" +msgstr "" + +#: src/natcap/invest/wave_energy.py:34 +msgid "Index of this percentile bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:38 +msgid "Percentile range within this bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:42 +msgid "Number of pixels whose wave energy values fall into this percentile bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:51 src/natcap/invest/wind_energy.py:331 +msgid "Unique identifier for each point." +msgstr "Identificador único para cada punto." + +#: src/natcap/invest/wave_energy.py:55 src/natcap/invest/wind_energy.py:335 +msgid "This is a land connection point" +msgstr "Este es un punto de conexión terrestre" + +#: src/natcap/invest/wave_energy.py:57 src/natcap/invest/wind_energy.py:337 +msgid "This is a grid connection point" +msgstr "Este es un punto de conexión a la cuadrícula" + +#: src/natcap/invest/wave_energy.py:60 src/natcap/invest/wind_energy.py:340 +msgid "The type of connection at this point." +msgstr "El tipo de conexión en este punto." + +#: src/natcap/invest/wave_energy.py:65 src/natcap/invest/wind_energy.py:345 +msgid "Latitude of the connection point." +msgstr "Latitud del punto de conexión." + +#: src/natcap/invest/wave_energy.py:70 src/natcap/invest/wind_energy.py:350 +msgid "Longitude of the connection point." +msgstr "Longitud del punto de conexión." + +#: src/natcap/invest/wave_energy.py:74 +msgid "Name for the connection point location." +msgstr "Nombre de la ubicación del punto de conexión." + +#: src/natcap/invest/wave_energy.py:149 +msgid "Point vector for the west coast of North America and Hawaii." +msgstr "Vector de puntos para la costa oeste de América del Norte y Hawái." + +#: src/natcap/invest/wave_energy.py:156 +msgid "Extract vector for the west coast of North America and Hawaii." +msgstr "Vector de extracción para la costa oeste de América del Norte y Hawái." + +#: src/natcap/invest/wave_energy.py:161 +msgid "WaveWatchIII data for the west coast of North America and Hawaii." +msgstr "Datos de WaveWatchIII para la costa oeste de Norteamérica y Hawai." + +#: src/natcap/invest/wave_energy.py:168 +msgid "Point vector for the East Coast of North America and Puerto Rico." +msgstr "Vector de puntos para la costa este de Norteamérica y Puerto Rico." + +#: src/natcap/invest/wave_energy.py:175 +msgid "Extract vector for the East Coast of North America and Puerto Rico." +msgstr "Vector de extracción para la costa este de Norteamérica y Puerto Rico." + +#: src/natcap/invest/wave_energy.py:180 +msgid "WaveWatchIII data for the East Coast of North America and Puerto Rico." +msgstr "Datos de WaveWatchIII para la costa este de Norteamérica y Puerto Rico." + +#: src/natcap/invest/wave_energy.py:187 +msgid "Point vector for the North Sea 4 meter resolution." +msgstr "Vector de puntos para el Mar del Norte con una resolución de 4 metros." + +#: src/natcap/invest/wave_energy.py:193 +msgid "Extract vector for the North Sea 4 meter resolution." +msgstr "Vector de extracción para el Mar del Norte con una resolución de 4 metros." + +#: src/natcap/invest/wave_energy.py:197 +msgid "WaveWatchIII data for the North Sea 4 meter resolution." +msgstr "" +"Datos de WaveWatchIII para el Mar del Norte con una resolución de 4 " +"metros." + +#: src/natcap/invest/wave_energy.py:204 +msgid "Point vector for the North Sea 10 meter resolution." +msgstr "Vector de puntos para el Mar del Norte con una resolución de 10 metros." + +#: src/natcap/invest/wave_energy.py:210 +msgid "Extract vector for the North Sea 10 meter resolution." +msgstr "" +"Vector de extracción para el Mar del Norte con una resolución de 10 " +"metros." + +#: src/natcap/invest/wave_energy.py:214 +msgid "WaveWatchIII data for the North Sea 10 meter resolution." +msgstr "" +"Datos de WaveWatchIII para el Mar del Norte con una resolución de 10 " +"metros." + +#: src/natcap/invest/wave_energy.py:221 +msgid "Point vector for Australia." +msgstr "Vector de puntos para Australia." + +#: src/natcap/invest/wave_energy.py:226 +msgid "Extract vector for Australia." +msgstr "Extraer el vector para Australia." + +#: src/natcap/invest/wave_energy.py:229 +msgid "WaveWatchIII data for Australia." +msgstr "Datos de WaveWatchIII para Australia." + +#: src/natcap/invest/wave_energy.py:234 +msgid "Global point vector." +msgstr "Vector global de puntos." + +#: src/natcap/invest/wave_energy.py:239 +msgid "Global extract vector." +msgstr "Vector de extracción global." + +#: src/natcap/invest/wave_energy.py:242 +msgid "Global WaveWatchIII data." +msgstr "Datos de Global WaveWatchIII." + +#: src/natcap/invest/wave_energy.py:244 +msgid "" +"Pre-packaged wave energy data directory. This is provided with the sample" +" data." +msgstr "" +"Directorio de datos de energía de las olas preempaquetado. Se proporciona" +" con los datos de muestra." + +#: src/natcap/invest/wave_energy.py:247 +msgid "wave base data" +msgstr "datos base de las olas" + +#: src/natcap/invest/wave_energy.py:252 +msgid "West Coast of North America and Hawaii" +msgstr "Costa Oeste de América del Norte y Hawái" + +#: src/natcap/invest/wave_energy.py:254 +msgid "East Coast of North America and Puerto Rico" +msgstr "Costa Este de Norteamérica y Puerto Rico" + +#: src/natcap/invest/wave_energy.py:257 +msgid "North Sea 4 meter resolution" +msgstr "Resolución de 4 metros de en el Mar del Norte" + +#: src/natcap/invest/wave_energy.py:259 +msgid "North Sea 10 meter resolution" +msgstr "Resolución de 10 metros en el Mar del Norte" + +#: src/natcap/invest/wave_energy.py:260 +msgid "Australia" +msgstr "Australia" + +#: src/natcap/invest/wave_energy.py:261 +msgid "Global" +msgstr "Global" + +#: src/natcap/invest/wave_energy.py:263 +msgid "The analysis area over which to run the model." +msgstr "El área de análisis sobre la que se ejecutará el modelo." + +#: src/natcap/invest/wave_energy.py:265 +msgid "analysis area" +msgstr "área de análisis" + +#: src/natcap/invest/wave_energy.py:275 +msgid "" +"A matrix of the wave machine performance, or ability to capture wave " +"energy, in different sea state conditions. The first column contains wave" +" height values (in meters, increasing from top to bottom), and the first " +"row contains wave period values (in seconds, increasing from left to " +"right). Values within the matrix are the machine performance in kilowatts" +" at that sea state condition, described by the wave height (row) and wave" +" period (column). The model linearly interpolates sea state data from the" +" base wave dataset onto this matrix to determine performance." +msgstr "" +"Una matriz del rendimiento de la máquina de olas, o de la capacidad de " +"captar la energía de las olas, en diferentes condiciones del estado del " +"mar. La primera columna contiene los valores de la altura de las olas (en" +" metros, aumentando de arriba hacia abajo), y la primera fila contiene " +"los valores del periodo de las olas (en segundos, aumentando de izquierda" +" a derecha). Los valores dentro de la matriz son el rendimiento de la " +"máquina en kilovatios en esa condición de estado del mar, descrita por la" +" altura de la ola (fila) y el período de la ola (columna). El modelo " +"interpola linealmente los datos del estado del mar del conjunto de datos " +"de olas base en esta matriz para determinar el rendimiento." + +#: src/natcap/invest/wave_energy.py:286 +msgid "machine performance table" +msgstr "tabla de rendimiento de la máquina" + +#: src/natcap/invest/wave_energy.py:295 +msgid "" +"Name of the machine parameter. Expected parameters are: 'capmax' (maximum" +" capacity for device, in kilowatts), 'hsmax' (upper limit of wave height " +"for device operation, in meters), and 'tpmax' (upper limit of wave period" +" for device operation, in seconds)." +msgstr "" + +#: src/natcap/invest/wave_energy.py:305 src/natcap/invest/wave_energy.py:354 +#, fuzzy +msgid "Value of the machine parameter." +msgstr "tabla de parámetros de la máquina" + +#: src/natcap/invest/wave_energy.py:308 +msgid "Table of parameters for the wave energy machine in use." +msgstr "Tabla de parámetros de la máquina de energía de las olas en uso." + +#: src/natcap/invest/wave_energy.py:309 +msgid "machine parameter table" +msgstr "tabla de parámetros de la máquina" + +#: src/natcap/invest/wave_energy.py:312 src/natcap/invest/wind_energy.py:128 +msgid "bathymetry" +msgstr "batimetría" + +#: src/natcap/invest/wave_energy.py:315 src/natcap/invest/wind_energy.py:127 +msgid "Map of ocean depth. Values should be negative." +msgstr "Mapa de la profundidad del océano. Los valores deben ser negativos." + +#: src/natcap/invest/scenic_quality/scenic_quality.py:121 +#: src/natcap/invest/wave_energy.py:320 +msgid "Run the valuation model." +msgstr "Ejecutar el modelo de valoración." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:353 +#: src/natcap/invest/scenic_quality/scenic_quality.py:118 +#: src/natcap/invest/wave_energy.py:321 src/natcap/invest/wind_energy.py:310 +msgid "run valuation" +msgstr "ejecutar validación" + +#: src/natcap/invest/wave_energy.py:327 +msgid "" +"A table of data for each connection point. Required if Run Valuation is " +"selected." +msgstr "" +"Una tabla de datos para cada punto de conexión. Se requiere si se " +"selecciona la opción de ejecución de la validación." + +#: src/natcap/invest/wave_energy.py:330 +msgid "grid connection points table" +msgstr "tabla de puntos de conexión a la cuadrícula" + +#: src/natcap/invest/wave_energy.py:339 +msgid "" +"Name of the machine parameter. Expected parameters are: 'capmax' (maximum" +" capacity for device, in kilowatts), 'cc' (capital cost per device " +"installed, $/kilowatt), 'cml' (cost of mooring lines, $/kilometer), 'cul'" +" (cost of underwater cable, $/kilometer), 'col' (cost of overland " +"transmission lines, $/kilometer), 'omc' (operating and maintenance cost, " +"$/kilowatt hour), 'p' (price of electricity, $/kilowatt hour), 'r' " +"(discount rate, between 0 and 1), 'smlpm' (number of slack lines required" +" per machine)" +msgstr "" + +#: src/natcap/invest/wave_energy.py:358 +msgid "" +"Table of economic parameters for the wave energy machine. Required if Run" +" Valuation is selected." +msgstr "" +"Tabla de parámetros económicos de la máquina de energía de las olas. Se " +"requiere si se selecciona la opción de ejecución de la valoración." + +#: src/natcap/invest/wave_energy.py:361 +msgid "machine economic table" +msgstr "cuadro económico de la máquina" + +#: src/natcap/invest/wave_energy.py:368 +msgid "Number of wave machines to model. Required if Run Valuation is selected." +msgstr "" +"Número de máquinas de olas a modelizar. Es necesario si se selecciona la " +"opción de ejecución de la validación." + +#: src/natcap/invest/wave_energy.py:371 +msgid "number of machines" +msgstr "número de máquinas" + +#: src/natcap/invest/wave_energy.py:379 +msgid "Map of captured wave energy per WEC device." +msgstr "" + +#: src/natcap/invest/wave_energy.py:387 +msgid "" +"Map of captured wave energy per WEC device reclassified by quantiles (1 =" +" < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +msgstr "" + +#: src/natcap/invest/wave_energy.py:394 +msgid "" +"Table of value ranges for each captured wave energy quantile group as " +"well as the number of pixels for each group." +msgstr "" + +#: src/natcap/invest/wave_energy.py:404 +msgid "Range of wave energy values within this percentile bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:412 +msgid "Vector map of the provided grid points" +msgstr "" + +#: src/natcap/invest/wave_energy.py:418 +msgid "Vector map of the provided land points" +msgstr "" + +#: src/natcap/invest/wave_energy.py:423 +msgid "" +"Map of positive values of net present value over the 25-year lifespan of " +"a wave energy facility, reclassified by quantiles (1 = < 25%, 2 = 25-50%," +" 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +msgstr "" + +#: src/natcap/invest/wave_energy.py:431 +msgid "" +"Table of value ranges for each net present value quantile group as well " +"as the number of pixels for each group." +msgstr "" + +#: src/natcap/invest/wave_energy.py:441 +msgid "Range of net present values within this percentile bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:448 +msgid "" +"Map of net present value over the 25-year lifespan of a wave energy " +"facility." +msgstr "" + +#: src/natcap/invest/wave_energy.py:457 +msgid "Map of potential wave power." +msgstr "" + +#: src/natcap/invest/wave_energy.py:464 +msgid "" +"Map of potential wave power classified into quantiles (1 = < 25%, 2 = " +"25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +msgstr "" + +#: src/natcap/invest/wave_energy.py:471 +msgid "" +"Table of value ranges for each wave power quantile group as well as the " +"number of pixels for each group." +msgstr "" + +#: src/natcap/invest/wave_energy.py:480 +msgid "Range of potential wave power values within this percentile bin." +msgstr "" + +#: src/natcap/invest/wind_energy.py:36 +msgid "Longitude of the data point." +msgstr "Longitud del punto de datos." + +#: src/natcap/invest/wind_energy.py:41 +msgid "Latitude of the data point." +msgstr "Latitud del punto de datos." + +#: src/natcap/invest/wind_energy.py:46 src/natcap/invest/wind_energy.py:76 +msgid "Weibull scale factor at the reference hub height at this point." +msgstr "" +"Factor de escala de Weibull en la altura del buje de referencia en este " +"punto." + +#: src/natcap/invest/wind_energy.py:53 +msgid "Weibull shape factor at this point." +msgstr "Factor de forma de Weibull en este punto." + +#: src/natcap/invest/wind_energy.py:58 +#, fuzzy +msgid "" +"The reference hub height at this point, at which wind speed data was " +"collected and LAM was estimated." +msgstr "" +"La altura del buje de referencia en este punto, en el que se recogieron " +"los datos de la velocidad del viento y se estimó el LAM." + +#: src/natcap/invest/wind_energy.py:69 +#, fuzzy +msgid "Weibull scale factor calculated for the proposed hub height at this point." +msgstr "" +"Factor de escala de Weibull en la altura del buje de referencia en este " +"punto." + +#: src/natcap/invest/wind_energy.py:83 +#, fuzzy +msgid "Power density at this point." +msgstr "Factor de forma de Weibull en este punto." + +#: src/natcap/invest/wind_energy.py:88 +msgid "Predicted energy harvested from a wind farm centered on this point." +msgstr "" + +#: src/natcap/invest/wind_energy.py:110 +msgid "Table of Weibull parameters for each wind data point." +msgstr "Tabla de parámetros de Weibull para cada punto de datos de viento." + +#: src/natcap/invest/wind_energy.py:111 +msgid "wind data points" +msgstr "puntos de datos del viento" + +#: src/natcap/invest/wind_energy.py:118 +msgid "" +"Map of the area(s) of interest over which to run the model and aggregate " +"valuation results. Required if Run Valuation is selected and the Grid " +"Connection Points table is provided." +msgstr "" +"Mapa de la(s) zona(s) de interés sobre la(s) cual(es) se ejecuta el " +"modelo y se agregan los resultados de la valoración. Se requiere si se " +"selecciona la opción de ejecutar valoración y se proporciona la tabla de " +"Puntos de conexión a la cuadrícula." + +#: src/natcap/invest/wind_energy.py:135 +msgid "" +"Map of the coastlines of landmasses in the area of interest. Required if " +"the Minimum Distance and Maximum Distance inputs are provided." +msgstr "" +"Mapa de las líneas de costa de las masas de tierra en el área de interés." +" Se requiere si se proporcionan los inputs de Distancia mínima y " +"Distancia máxima." + +#: src/natcap/invest/wind_energy.py:139 +msgid "land polygon" +msgstr "polígono de tierra" + +#: src/natcap/invest/wind_energy.py:147 +msgid "Standard atmosphere air density." +msgstr "Densidad del aire de la atmósfera estándar." + +#: src/natcap/invest/wind_energy.py:151 +msgid "Exponent to use in the power curve function." +msgstr "Exponente a utilizar en la función de la curva de potencia." + +#: src/natcap/invest/wind_energy.py:154 +msgid "" +"Cost to decommission a turbine as a proportion of the total upfront costs" +" (cables, foundations, installation?)" +msgstr "" +"Costo de desmantelamiento de una turbina en proporción a los costos " +"iniciales totales (cables, cimientos, instalación...)" + +#: src/natcap/invest/wind_energy.py:161 +msgid "The operations and maintenance costs as a proportion of capex_arr" +msgstr "Los costes de operación y mantenimiento como proporción del capex_arr" + +#: src/natcap/invest/wind_energy.py:166 +msgid "The miscellaneous costs as a proportion of capex_arr" +msgstr "Los gastos misceláneos como proporción de capex_arr" + +#: src/natcap/invest/wind_energy.py:171 +msgid "The installation costs as a proportion of capex_arr" +msgstr "Los costes de instalación como proporción del capex_arr" + +#: src/natcap/invest/wind_energy.py:177 +msgid "The length of infield cable." +msgstr "La longitud del cableado interior." + +#: src/natcap/invest/wind_energy.py:181 +msgid "The cost of infield cable." +msgstr "El costo del cableado interior." + +#: src/natcap/invest/wind_energy.py:185 +msgid "Cost of AC cable that scales with capacity." +msgstr "Costo del cable de corriente alterna que se adapta a la capacidad." + +#: src/natcap/invest/wind_energy.py:189 +msgid "Cost of DC cable that scales with capacity." +msgstr "Costo del cable de corriente continua que se adapta a la capacidad." + +#: src/natcap/invest/wind_energy.py:193 +msgid "Cost of AC cable that scales with length." +msgstr "Costo del cable de corriente alterna que aumenta con la longitud." + +#: src/natcap/invest/wind_energy.py:197 +msgid "Cost of DC cable that scales with length." +msgstr "Costo del cable de corriente continua que aumenta con la longitud." + +#: src/natcap/invest/wind_energy.py:201 +msgid "" +"The threshold above which a wind farm’s distance from the grid requires a" +" switch from AC to DC power to overcome line losses which reduce the " +"amount of energy delivered" +msgstr "" +"El umbral a partir del cual la distancia de un parque eólico a la red " +"requiere un cambio de CA a CC para superar las pérdidas de la línea que " +"reducen la cantidad de energía suministrada" + +#: src/natcap/invest/wind_energy.py:209 +msgid "The expected lifetime of the facility" +msgstr "La vida útil prevista de la instalación" + +#: src/natcap/invest/wind_energy.py:213 +msgid "" +"Factor that translates carbon-free wind power to a corresponding amount " +"of avoided CO2 emissions" +msgstr "" +"Factor que traduce la energía eólica libre de carbono en una cantidad " +"correspondiente de emisiones de CO2 evitadas" + +#: src/natcap/invest/wind_energy.py:219 +msgid "The reduction in air density per meter above sea level" +msgstr "La reducción de la densidad del aire por metro sobre el nivel del mar" + +#: src/natcap/invest/wind_energy.py:224 +msgid "" +"The fraction of energy lost due to downtime, power conversion " +"inefficiency, and electrical grid losses" +msgstr "" +"La fracción de energía que se pierde debido al tiempo de inactividad, la " +"ineficiencia de la conversión de energía y las pérdidas de la red " +"eléctrica" + +#: src/natcap/invest/wind_energy.py:228 +msgid "A table of wind energy infrastructure parameters." +msgstr "Tabla de parámetros de la infraestructura de la energía eólica." + +#: src/natcap/invest/wind_energy.py:230 +msgid "global wind energy parameters" +msgstr "parámetros globales de la energía eólica" + +#: src/natcap/invest/wind_energy.py:238 +msgid "Height of the turbine hub above sea level." +msgstr "Altura del buje de la turbina sobre el nivel del mar." + +#: src/natcap/invest/wind_energy.py:242 +msgid "Wind speed at which the turbine begins producing power." +msgstr "Velocidad del viento a la que la turbina empieza a producir energía." + +#: src/natcap/invest/wind_energy.py:248 +msgid "Minimum wind speed at which the turbine reaches its rated power output." +msgstr "" +"Velocidad mínima del viento a la que la turbina alcanza su potencia " +"nominal." + +#: src/natcap/invest/wind_energy.py:254 +msgid "" +"Wind speed above which the turbine stops generating power for safety " +"reasons." +msgstr "" +"Velocidad del viento por encima de la cual la turbina deja de generar " +"energía por razones de seguridad." + +#: src/natcap/invest/wind_energy.py:260 +msgid "The turbine's rated power output." +msgstr "La potencia nominal de la turbina." + +#: src/natcap/invest/wind_energy.py:264 +msgid "The cost of one turbine." +msgstr "El coste de una turbina." + +#: src/natcap/invest/wind_energy.py:266 +msgid "A table of parameters specific to the type of turbine." +msgstr "Una tabla de parámetros específicos para el tipo de turbina." + +#: src/natcap/invest/wind_energy.py:267 +msgid "turbine parameters" +msgstr "parámetros de la turbina" + +#: src/natcap/invest/wind_energy.py:273 +msgid "The number of wind turbines per wind farm." +msgstr "El número de aerogeneradores por parque eólico." + +#: src/natcap/invest/wind_energy.py:274 +msgid "number of turbines" +msgstr "número de turbinas" + +#: src/natcap/invest/wind_energy.py:279 +msgid "Minimum depth for offshore wind farm installation." +msgstr "Profundidad mínima para la instalación de parques eólicos en alta mar." + +#: src/natcap/invest/wind_energy.py:280 +msgid "minimum depth" +msgstr "profundidad mínima" + +#: src/natcap/invest/wind_energy.py:285 +msgid "Maximum depth for offshore wind farm installation." +msgstr "Profundidad máxima para la instalación de parques eólicos en alta mar." + +#: src/natcap/invest/wind_energy.py:286 +msgid "maximum depth" +msgstr "profundidad máxima" + +#: src/natcap/invest/wind_energy.py:292 +msgid "" +"Minimum distance from shore for offshore wind farm installation. Required" +" if Run Valuation is selected." +msgstr "" +"Distancia mínima desde la costa para la instalación de un parque eólico " +"marino. Se necesita si se selecciona la opción de ejecución de " +"valoración." + +#: src/natcap/invest/wind_energy.py:295 +msgid "minimum distance" +msgstr "distancia mínima" + +#: src/natcap/invest/wind_energy.py:301 +msgid "" +"Maximum distance from shore for offshore wind farm installation. Required" +" if Run Valuation is selected." +msgstr "" +"Distancia máxima desde la costa para la instalación del parque eólico " +"marino. Se necesita si se selecciona la opción de ejecución de " +"evaluación." + +#: src/natcap/invest/wind_energy.py:304 +msgid "maximum distance" +msgstr "distancia máxima" + +#: src/natcap/invest/wind_energy.py:309 +msgid "Run the valuation component of the model." +msgstr "Ejecute el componente de valoración del modelo." + +#: src/natcap/invest/wind_energy.py:316 +msgid "The cost of the foundation for one turbine." +msgstr "El coste de los cimientos de una turbina." + +#: src/natcap/invest/wind_energy.py:317 +msgid "foundation cost" +msgstr "coste de la cimentación" + +#: src/natcap/invest/wind_energy.py:322 +msgid "Annual discount rate to apply to valuation." +msgstr "Tasa de descuento anual a aplicar en la valoración." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:408 +#: src/natcap/invest/wind_energy.py:323 +msgid "discount rate" +msgstr "tasa de descuento" + +#: src/natcap/invest/wind_energy.py:354 +msgid "" +"Table of grid and land connection points to which cables will connect. " +"Required if Run Valuation is selected and Average Shore-to-Grid Distance " +"is not provided." +msgstr "" +"Tabla de puntos de conexión a la red y a tierra a los que se conectarán " +"los cables. Necesario si se selecciona la opción de valoración de la " +"ejecución y no se proporciona la distancia media de la orilla a la red." + +#: src/natcap/invest/wind_energy.py:358 +msgid "grid connection points" +msgstr "puntos de conexión a la cuadrícula" + +#: src/natcap/invest/wind_energy.py:365 +#, fuzzy +msgid "" +"Average distance to the onshore grid from coastal cable landing points. " +"Required if Run Valuation is selected and the Grid Connection Points " +"table is not provided." +msgstr "" +"Distancia media a la red terrestre desde los puntos de desembarco del " +"cable costero. Necesario si se selecciona la opción de valoración de la " +"ejecución y no se proporciona la tabla de Puntos de conexión a la red." + +#: src/natcap/invest/wind_energy.py:369 +msgid "average shore-to-grid distance" +msgstr "distancia media entre la costa y la red" + +#: src/natcap/invest/wind_energy.py:374 +msgid "" +"Use a Wind Energy Price Table instead of calculating annual prices from " +"the initial Energy Price and Rate of Price Change inputs." +msgstr "" +"Utilizar una tabla de precios de la energía eólica en lugar de calcular " +"los precios anuales a partir de los inputs iniciales del precio de la " +"energía y la tasa de variación del precio." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:362 +#: src/natcap/invest/wind_energy.py:378 +msgid "use price table" +msgstr "utilizar la tabla de precios" + +#: src/natcap/invest/wind_energy.py:387 +msgid "" +"Consecutive years for each year in the lifespan of the wind farm. These " +"may be the actual years: 2010, 2011, 2012..., or the number of the years " +"after the starting date: 1, 2, 3,..." +msgstr "" +"Años consecutivos para cada año de la vida útil del parque eólico. Pueden" +" ser los años reales: 2010, 2011, 2012..., o el número de los años " +"posteriores a la fecha de inicio: 1, 2, 3,..." + +#: src/natcap/invest/wind_energy.py:396 +msgid "Price of energy for each year." +msgstr "Precio de la energía para cada año." + +#: src/natcap/invest/wind_energy.py:400 +msgid "" +"Table of yearly prices for wind energy. There must be a row for each year" +" in the lifespan given in the 'time_period' column in the Global Wind " +"Energy Parameters table. Required if Run Valuation and Use Price Table " +"are selected." +msgstr "" +"Tabla de precios anuales de la energía eólica. Debe haber una fila por " +"cada año de la vida útil indicada en la columna \"time_period\" de la " +"tabla Global Wind Energy Parameters. Se requiere si se seleccionan las " +"opciones de valoración de la ejecución y la de utilización de la Tabla de" +" precios." + +#: src/natcap/invest/wind_energy.py:405 +msgid "wind energy price table" +msgstr "tabla de precios de la energía eólica" + +#: src/natcap/invest/wind_energy.py:411 +#, fuzzy +msgid "" +"The initial price of wind energy, at the first year in the wind energy " +"farm lifespan. Required if Run Valuation is selected and Use Price Table " +"is not selected." +msgstr "" +"El precio inicial de la energía eólica, en el primer año de la vida útil " +"del parque eólico. Requerido si se seleccionan las opciones de valoración" +" de ejecución y no se selecciona la de utilizar Tabla de precios." + +#: src/natcap/invest/wind_energy.py:415 +msgid "price of energy" +msgstr "precio de la energía" + +#: src/natcap/invest/wind_energy.py:420 +#, fuzzy +msgid "" +"The annual rate of change in the price of wind energy. Required if Run " +"Valuation is selected and Use Price Table is not selected." +msgstr "" +"La tasa de variación anual del precio de la energía eólica. Requerido si " +"se selecciona la opción de ejecución de valoración y no se selecciona la " +"de utilización de la Tabla de precios." + +#: src/natcap/invest/wind_energy.py:424 +msgid "rate of price change" +msgstr "tasa de variación de los precios" + +#: src/natcap/invest/wind_energy.py:432 +msgid "Map of offset carbon emissions for a farm centered on each pixel" +msgstr "" + +#: src/natcap/invest/wind_energy.py:441 +msgid "Map of power density." +msgstr "" + +#: src/natcap/invest/wind_energy.py:448 +msgid "Map of energy harvested from a farm centered on each pixel." +msgstr "" + +#: src/natcap/invest/wind_energy.py:456 +msgid "" +"Map of the energy price that would be required to set the present value " +"of a farm centered on each pixel equal to zero." +msgstr "" + +#: src/natcap/invest/wind_energy.py:466 +msgid "Map of the net present value of a farm centered on each pixel." +msgstr "" + +#: src/natcap/invest/wind_energy.py:471 +msgid "Map of summarized data at each point." +msgstr "" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:116 +#, fuzzy +msgid "" +"Analysis year {analysis_year} must be >= the latest snapshot year " +"({latest_year})" +msgstr "" +"El año de análisis {analysis_year} debe ser >= el último año de la " +"instantánea ({latest_year})" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:119 +#, fuzzy +msgid "Raster for snapshot {snapshot_year} could not be validated." +msgstr "No se ha podido validar la trama de la instantánea {snapshot_year}." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:121 +msgid "" +"The transition table expects values of {model_transitions} but found " +"values of {transition_values}." +msgstr "" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:177 +msgid "" +"The snapshot year that this row's LULC raster represents. Each year in " +"this table must be unique." +msgstr "" +"El año de la instantánea que representa el ráster LULC de esta fila. Cada" +" año de esta tabla debe ser único." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:184 +msgid "" +"Map of LULC in the given snapshot year. All values in this raster must " +"have corresponding entries in the Biophysical Table and Landcover " +"Transitions Table." +msgstr "" +"Mapa de LULC en el año de la instantánea. Todos los valores de este " +"ráster deben tener los inputs correspondientes en la Tabla Biofísica y en" +" la Tabla de Transiciones de la Cubierta Terrestre." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:191 +msgid "A table mapping snapshot years to corresponding LULC maps." +msgstr "" +"Una tabla que relaciona los años de la instantánea con los mapas LULC " +"correspondientes." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:193 +msgid "landcover snapshots table" +msgstr "tabla de instantáneas de la cubierta vegetal" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:199 +msgid "analysis year" +msgstr "año de análisis" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:200 +msgid "" +"A year that may be used to extend the analysis beyond the last snapshot " +"year. If used, the model assumes that carbon will continue to accumulate " +"or emit after the last snapshot year until the analysis year. This value " +"must be greater than the final snapshot year." +msgstr "" +"Un año que puede utilizarse para ampliar el análisis más allá del último " +"año de la instantánea. Si se utiliza, el modelo asume que el carbono " +"seguirá acumulándose o emitiéndose después del último año de la " +"instantánea hasta el año de análisis. Este valor debe ser mayor que el " +"último año de la instantánea." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:214 +msgid "" +"The LULC code that represents this LULC class in the LULC snapshot " +"rasters." +msgstr "" +"El código LULC que representa esta clase LULC en los rastreos de " +"instantáneas LULC." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:219 +msgid "" +"Name of the LULC class. This label must be unique among the all the LULC " +"classes." +msgstr "" +"Nombre de la clase LULC. Esta etiqueta debe ser única entre todas las " +"clases LULC." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:225 +msgid "The initial carbon stocks in the biomass pool for this LULC class." +msgstr "" +"Las existencias iniciales de carbono en la reserva de biomasa para esta " +"clase de LULC." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:231 +msgid "The initial carbon stocks in the soil pool for this LULC class." +msgstr "" +"Las existencias iniciales de carbono en la reserva del suelo para esta " +"clase de LULC." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:237 +msgid "The initial carbon stocks in the litter pool for this LULC class." +msgstr "" +"Las existencias iniciales de carbono en la reserva de hojarasca para esta" +" clase de LULC." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:244 +msgid "The half-life of carbon in the biomass pool." +msgstr "La vida media del carbono en la reserva de biomasa." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:247 +msgid "" +"Proportion of carbon stock in the biomass pool that is disturbed when a " +"cell transitions away from this LULC class in a low-impact disturbance." +msgstr "" +"Proporción de las existencias de carbono en la reserva de biomasa que se " +"perturba cuando una celda se aleja de esta clase de LULC en una " +"perturbación de bajo impacto." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:253 +msgid "" +"Proportion of carbon stock in the biomass pool that is disturbed when a " +"cell transitions away from this LULC class in a medium-impact " +"disturbance." +msgstr "" +"Proporción de las existencias de carbono en la reserva de biomasa que se " +"ve perturbada cuando una celda se aleja de esta clase de LULC en una " +"perturbación de impacto medio." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:259 +msgid "" +"Proportion of carbon stock in the biomass pool that is disturbed when a " +"cell transitions away from this LULC class in a high-impact disturbance." +msgstr "" +"Proporción de las existencias de carbono en la reserva de biomasa que se " +"perturba cuando una celda se aleja de esta clase de LULC en una " +"perturbación de alto impacto." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:266 +msgid "Annual rate of CO2E accumulation in the biomass pool." +msgstr "Tasa anual de acumulación de CO2E en la reserva de biomasa." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:272 +msgid "The half-life of carbon in the soil pool." +msgstr "La vida media del carbono en la reserva del suelo." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:275 +msgid "" +"Proportion of carbon stock in the soil pool that is disturbed when a cell" +" transitions away from this LULC class in a low-impact disturbance." +msgstr "" +"Proporción de las existencias de carbono en la reserva de suelo que se " +"perturba cuando una celda se aleja de esta clase de LULC en una " +"perturbación de bajo impacto." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:281 +msgid "" +"Proportion of carbon stock in the soil pool that is disturbed when a cell" +" transitions away from this LULC class in a medium-impact disturbance." +msgstr "" +"Proporción de las existencias de carbono en la reserva de suelo que se " +"perturba cuando una celda se aleja de esta clase de LULC en una " +"perturbación de impacto medio." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:287 +msgid "" +"Proportion of carbon stock in the soil pool that is disturbed when a cell" +" transitions away from this LULC class in a high-impact disturbance." +msgstr "" +"Proporción de las existencias de carbono en la reserva de suelo que se " +"perturba cuando una célula se aleja de esta clase de LULC en una " +"perturbación de alto impacto." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:294 +msgid "Annual rate of CO2E accumulation in the soil pool." +msgstr "Tasa anual de acumulación de CO2E en la reserva del suelo." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:299 +msgid "Annual rate of CO2E accumulation in the litter pool." +msgstr "Tasa anual de acumulación de CO2E en la reserva de hojarasca." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:302 +msgid "Table of biophysical properties for each LULC class." +msgstr "Tabla de propiedades biofísicas para cada clase de LULC." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:305 +msgid "landcover transitions table" +msgstr "tabla de transiciones de la cubierta vegetal" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:311 +#, fuzzy +msgid "LULC class names matching those in the biophysical table." +msgstr "Códigos LULC que coinciden con los códigos de la tabla biofísica." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:318 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:97 +msgid "a state of carbon accumulation" +msgstr "un estado de acumulación de carbono" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:321 +msgid "high carbon disturbance rate" +msgstr "alto índice de perturbación del carbono" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:324 +msgid "medium carbon disturbance rate" +msgstr "índice de perturbación del carbono medio" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:327 +msgid "low carbon disturbance rate" +msgstr "bajo índice de perturbación del carbono" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:330 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:106 +msgid "no change in carbon" +msgstr "ningún cambio en el carbono" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:333 +#, fuzzy +msgid "" +"A transition matrix describing the type of carbon action that occurs when" +" each LULC type transitions to each other type. Values in the first " +"column, 'lulc-class', represents the original LULC class that is " +"transitioned away from. Values in the first row represents the LULC class" +" that is transitioned to. Each cell in the matrix is filled with an " +"option indicating the effect on carbon when transitioning from that " +"cell's row's LULC class to that cell's column's LULC class. The classes " +"in this table must exactly match the classes in the Biophysical Table " +"'lulc-class' column. A cell may be left empty if the transition never " +"occurs." +msgstr "" +"Una matriz de transición que describe el tipo de acción de carbono que se" +" produce cuando cada tipo de LULC hace la transición a otro tipo. Los " +"valores de la primera columna, \"lulc-class\", representan la clase LULC " +"original de la que se produce la transición. Los valores de la primera " +"fila representan la clase LULC a la que se produce la transición. Cada " +"celda de la matriz se rellena con una opción que indica el efecto sobre " +"el carbono al pasar de la clase LULC de la fila de esa celda a la clase " +"LULC de la columna de esa celda. Las clases de esta tabla deben coincidir" +" exactamente con las clases de la columna \"lulc-class\" de la tabla " +"biofísica. Una celda puede dejarse vacía si la transición no se produce " +"nunca." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:348 +msgid "" +"A transition matrix mapping the type of carbon action undergone when one " +"LULC type transitions to another." +msgstr "" +"Una matriz de transición que mapea el tipo de acción del carbono que se " +"produce cuando un tipo de LULC transiciona a otro." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:356 +msgid "" +"Enable net present valuation analysis based on carbon prices from either " +"a yearly price table, or an initial price and yearly interest rate." +msgstr "" +"Permitir el análisis de la valoración actual neta basada en los precios " +"del carbono a partir de una tabla de precios anuales, o de un precio " +"inicial y un tipo de interés anual." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:365 +msgid "" +"Use a yearly price table, rather than an initial price and interest rate," +" to indicate carbon value over time." +msgstr "" +"Utilice una tabla de precios anuales, en lugar de un precio inicial y un " +"tipo de interés, para indicar el valor del carbono a lo largo del tiempo." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:370 +msgid "price" +msgstr "precio" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:374 +#, fuzzy +msgid "" +"The price of CO2E at the baseline year. Required if Do Valuation is " +"selected and Use Price Table is not selected." +msgstr "" +"El precio del CO2E en el año de referencia. Es necesario si se selecciona" +" la opción de ejecución de valoración y no se selecciona la de utilizar " +"la Tabla de precios." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:379 +msgid "interest rate" +msgstr "tipo de interés" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:382 +msgid "" +"Annual increase in the price of CO2E. Required if Do Valuation is " +"selected and Use Price Table is not selected." +msgstr "" +"Incremento anual del precio del CO2E. Es necesario si se selecciona la " +"opción de hacer valoración y no se selecciona la de utilizar la Tabla de " +"precios." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:387 +msgid "price table" +msgstr "tabla de precios" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:395 +msgid "Each year from the snapshot year to analysis year." +msgstr "Cada año, desde el año de la instantánea hasta el año de análisis." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:400 +msgid "Price of CO2E in that year." +msgstr "Precio del CO2E en ese año." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:402 +#, fuzzy +msgid "" +"Table of annual CO2E prices for each year from the baseline year to the " +"final snapshot or analysis year. Required if Do Valuation is selected and" +" Use Price Table is selected." +msgstr "" +"Tabla de precios anuales de CO2E para cada año desde el año de referencia" +" hasta la instantánea final o el año de análisis. Se requiere si se " +"selecciona las opciones de ejecutar valoración y usar Tabla de precios." + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:411 +#, fuzzy +msgid "" +"Annual discount rate on the price of carbon. This is compounded each year" +" after the baseline year. Required if Run Valuation is selected." +msgstr "" +"Tasa de descuento anual sobre el precio del carbono. Se compone cada año " +"después del año de referencia. Se requiere si se selecciona la Valoración" +" de la Ejecución." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:33 +msgid "LULC lookup table" +msgstr "Tabla de consulta LULC" + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:35 +msgid "" +"A table mapping LULC codes from the snapshot rasters to the corresponding" +" LULC class names, and whether or not the class is a coastal blue carbon " +"habitat." +msgstr "" +"Una tabla que mapea los códigos LULC de los rásters de las instantáneas " +"con los nombres de las clases LULC correspondientes, y si la clase es o " +"no un hábitat costero de carbono azul." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:43 +msgid "" +"LULC code. Every value in the snapshot LULC maps must have a " +"corresponding entry in this column." +msgstr "" +"Código LULC. Cada valor de los mapas LULC de la instantánea debe tener un" +" input correspondiente en esta columna." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:49 +msgid "Name of the LULC class." +msgstr "Nombre de la clase LULC." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:52 +#, fuzzy +msgid "" +"Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if " +"not." +msgstr "" +"Introduzca TRUE si esta clase LULC es un hábitat costero de carbono azul," +" FALSE si no." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:63 +msgid "Year to snapshot." +msgstr "Año para la instantánea." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:67 +msgid "" +"Map of LULC in the snapshot year. All values in this raster must have " +"corresponding entries in the LULC Lookup table." +msgstr "" +"Mapa de LULC en el año de la instantánea. Todos los valores de este " +"ráster deben tener los inputs correspondientes en la tabla LULC Lookup." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:73 +msgid "A table mapping snapshot years to corresponding LULC maps for each year." +msgstr "" +"Una tabla que relaciona los años de la instantánea con los mapas LULC " +"correspondientes a cada año." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:76 +msgid "LULC snapshots table" +msgstr "Tabla de instantáneas LULC" + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:90 +msgid "LULC codes matching the codes in the biophysical table." +msgstr "Códigos LULC que coinciden con los códigos de la tabla biofísica." + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:100 +msgid "" +"Carbon disturbance occurred. Replace this with one of ‘low-impact-" +"disturb’, ‘med-impact-disturb’, or ‘high-impact-disturb’ to indicate the " +"degree of disturbance." +msgstr "" + +#: src/natcap/invest/delineateit/delineateit.py:46 +msgid "" +"Detect pour points (watershed outlets) based on the DEM, and use these " +"instead of a user-provided outlet features vector." +msgstr "" +"Detectar los puntos de vertido (salidas de la cuenca) basándose en el " +"MDE, y utilizarlos en lugar de un vector de características de salida " +"proporcionado por la persona usuaria." + +#: src/natcap/invest/delineateit/delineateit.py:50 +msgid "detect pour points" +msgstr "detección de puntos de vertido" + +#: src/natcap/invest/delineateit/delineateit.py:57 +#, fuzzy +msgid "" +"A map of watershed outlets from which to delineate the watersheds. " +"Required if Detect Pour Points is not checked." +msgstr "" +"Un mapa de puntos de vertido a partir del cual delinear las cuencas " +"hidrográficas. Se requiere si no se marca la opción Detectar puntos de " +"vertido." + +#: src/natcap/invest/delineateit/delineateit.py:60 +msgid "watershed outlets" +msgstr "puntos de salida de la cuenca" + +#: src/natcap/invest/delineateit/delineateit.py:65 +#, fuzzy +msgid "" +"Whether to snap point geometries to the nearest stream pixel. If " +"``True``, ``args['flow_threshold']`` and ``args['snap_distance']`` must " +"also be defined. If a point is equally near to more than one stream " +"pixel, it will be snapped to the stream pixel with the highest flow " +"accumulation value. This has no effect if Detect Pour Points is selected." +msgstr "" +"Si se ajustan las geometrías de los puntos al píxel de flujo más cercano." +" Si es ``Verdadero``, ``args['flow_threshold']`` y " +"``args['snap_distance']`` también deben ser definidos. Si un punto está " +"igualmente cerca de más de un píxel de la corriente, se ajustará al píxel" +" de la corriente con el mayor valor de acumulación de flujo. Esto no " +"tiene efecto si se selecciona la opción Detectar puntos de vertido." + +#: src/natcap/invest/delineateit/delineateit.py:73 +msgid "snap points to the nearest stream" +msgstr "ajustar puntos a la corriente más cercana" + +#: src/natcap/invest/delineateit/delineateit.py:78 +#, fuzzy +msgid "about Required if Snap Points is selected." +msgstr "sobre Requerido si se selecciona Puntos de ajuste." + +#: src/natcap/invest/delineateit/delineateit.py:87 +#, fuzzy +msgid "" +"Maximum distance to relocate watershed outlet points in order to snap " +"them to a stream. Required if Snap Points is selected." +msgstr "" +"Distancia máxima para reubicar los puntos de salida de la cuenca con el " +"fin de ajustarlos a una corriente. Se requiere si se selecciona Ajustar " +"puntos." + +#: src/natcap/invest/delineateit/delineateit.py:91 +msgid "snap distance" +msgstr "distancia de ajuste" + +#: src/natcap/invest/delineateit/delineateit.py:96 +#, fuzzy +msgid "" +"Skip delineation for any invalid geometries found in the Outlet Features." +" Otherwise, an invalid geometry will cause the model to crash." +msgstr "" +"Omitir la delineación para cualquier geometría no válida encontrada en " +"las Características de salida. De lo contrario, una geometría no válida " +"hará que el modelo se bloquee." + +#: src/natcap/invest/delineateit/delineateit.py:100 +msgid "skip invalid geometries" +msgstr "omitir geometrías no válidas" + +#: src/natcap/invest/ndr/ndr.py:26 +#, fuzzy +msgid "Either calc_n or calc_p must be True" +msgstr "O bien calc_n o bien calc_p debe ser True" + +#: src/natcap/invest/ndr/ndr.py:48 +msgid "" +"All values in this raster must have corresponding entries in the " +"Biophysical table." +msgstr "" +"Todos los valores de este ráster deben tener sus inputs correspondientes " +"en la Tabla Biofísica." + +#: src/natcap/invest/ndr/ndr.py:58 +msgid "" +"Map of runoff potential, the capacity to transport nutrients downslope. " +"This can be a quickflow index or annual precipitation. Any units are " +"allowed since the values will be normalized by their average." +msgstr "" +"Mapa del potencial de escorrentía, la capacidad de transportar nutrientes" +" pendiente abajo. Puede ser un índice de flujo rápido o una " +"precipitación anual. Se permite cualquier unidad ya que los valores se " +"normalizarán por su promedio." + +#: src/natcap/invest/ndr/ndr.py:63 +msgid "nutrient runoff proxy" +msgstr "proxy de escorrentía de nutrientes" + +#: src/natcap/invest/ndr/ndr.py:70 +msgid "" +"Map of the boundaries of the watershed(s) over which to aggregate the " +"model results." +msgstr "" +"Mapa de los límites de la(s) cuenca(s) sobre la(s) cual(es) se agregan " +"los resultados del modelo." + +#: src/natcap/invest/ndr/ndr.py:83 +msgid "The nutrient loading for this land use class." +msgstr "La carga de nutrientes para esta clase de uso del suelo." + +#: src/natcap/invest/ndr/ndr.py:87 +msgid "" +"Maximum nutrient retention efficiency. This is the maximum proportion of " +"the nutrient that is retained on this LULC class." +msgstr "" +"Eficiencia máxima de retención de nutrientes. Es la proporción máxima del" +" nutriente que se retiene en esta clase de LULC." + +#: src/natcap/invest/ndr/ndr.py:94 +#, fuzzy +msgid "" +"The distance after which it is assumed that this LULC type retains the " +"nutrient at its maximum capacity. If nutrients travel a shorter distance " +"that this, the retention efficiency will be less than the maximum value " +"eff_x, following an exponential decay." +msgstr "" +"La distancia tras la cual se supone que este tipo de LULC retiene el " +"nutriente a su máxima capacidad. Si los nutrientes recorren una distancia" +" menor que esta, la eficiencia de retención será menor que el valor " +"máximo eff_x, siguiendo un decaimiento exponencial." + +#: src/natcap/invest/ndr/ndr.py:104 +msgid "" +"The proportion of the total amount of nitrogen that are dissolved into " +"the subsurface. By default, this value should be set to 0, indicating " +"that all nutrients are delivered via surface flow. There is no equivalent" +" of this for phosphorus." +msgstr "" +"La proporción de la cantidad total de nitrógeno que se disuelve en el " +"subsuelo. Por defecto, este valor debe fijarse en 0, lo que indica que " +"todos los nutrientes se suministran a través del flujo superficial. No " +"existe un equivalente de esto para el fósforo." + +#: src/natcap/invest/ndr/ndr.py:111 +msgid "" +"A table mapping each LULC class to its biophysical properties related to " +"nutrient load and retention. Replace '[NUTRIENT]' in the column names " +"with 'n' or 'p' for nitrogen or phosphorus respectively. Nitrogen data " +"must be provided if Calculate Nitrogen is selected. Phosphorus data must " +"be provided if Calculate Phosphorus is selected. All LULC codes in the " +"LULC raster must have corresponding entries in this table." +msgstr "" +"Una tabla que asigna cada clase de LULC a sus propiedades biofísicas " +"relacionadas con la carga y la retención de nutrientes. Sustituya " +"\"[NUTRIENTE]\" en los nombres de las columnas por \"n\" o \"p\" para el " +"nitrógeno o el fósforo, respectivamente. Los datos de nitrógeno deben " +"proporcionarse si se selecciona Calcular nitrógeno. Los datos de fósforo " +"deben proporcionarse si se selecciona Calcular fósforo. Todos los códigos" +" LULC en el ráster LULC deben tener los inputs correspondientes en esta " +"tabla." + +#: src/natcap/invest/ndr/ndr.py:124 +msgid "Calculate phosphorus retention and export." +msgstr "Calcular la retención y la exportación de fósforo." + +#: src/natcap/invest/ndr/ndr.py:125 +msgid "calculate phosphorus" +msgstr "calcular el fósforo" + +#: src/natcap/invest/ndr/ndr.py:129 +msgid "Calculate nitrogen retention and export." +msgstr "Calcular la retención y la exportación de nitrógeno." + +#: src/natcap/invest/ndr/ndr.py:130 +msgid "calculate nitrogen" +msgstr "calcular el nitrógeno" + +#: src/natcap/invest/ndr/ndr.py:138 +msgid "" +"Calibration parameter that determines the shape of the relationship " +"between hydrologic connectivity (the degree of connection from patches of" +" land to the stream) and the nutrient delivery ratio (percentage of " +"nutrient that actually reaches the stream)." +msgstr "" +"Parámetro de calibración que determina la forma de la relación entre la " +"conectividad hidrológica (el grado de conexión de los parches de tierra " +"con la corriente) y la proporción de suministro de nutrientes (porcentaje" +" de nutrientes que realmente llegan a la corriente)." + +#: src/natcap/invest/ndr/ndr.py:144 src/natcap/invest/sdr/sdr.py:112 +msgid "Borselli k parameter" +msgstr "Parámetro k de Borselli" + +#: src/natcap/invest/ndr/ndr.py:150 +msgid "subsurface critical length (nitrogen)" +msgstr "longitud crítica en el subsuelo (nitrógeno)" + +#: src/natcap/invest/ndr/ndr.py:151 +#, fuzzy +msgid "" +"The distance traveled (subsurface and downslope) after which it is " +"assumed that soil retains nitrogen at its maximum capacity. Required if " +"Calculate Nitrogen is selected." +msgstr "" +"La distancia recorrida (subsuperficie y pendiente abajo) después de la " +"cual se supone que el suelo retiene el nitrógeno a su máxima capacidad. " +"Se requiere si se selecciona Calcular nitrógeno." + +#: src/natcap/invest/ndr/ndr.py:159 +msgid "subsurface maximum retention efficiency (nitrogen)" +msgstr "eficiencia máxima de retención subsuperficial (nitrógeno)" + +#: src/natcap/invest/ndr/ndr.py:160 +#, fuzzy +msgid "" +"The maximum nitrogen retention efficiency that can be reached through " +"subsurface flow. This characterizes the retention due to biochemical " +"degradation in soils. Required if Calculate Nitrogen is selected." +msgstr "" +"La máxima eficiencia de retención de nitrógeno que se puede alcanzar a " +"través del flujo subsuperficial. Caracteriza la retención debida a la " +"degradación bioquímica en los suelos. Se requiere si se selecciona " +"Calcular Nitrógeno." + +#: src/natcap/invest/recreation/recmodel_client.py:51 +msgid "A unique identifier for the predictor (10 characters or less)." +msgstr "Un identificador único para el predictor (10 caracteres o menos)." + +#: src/natcap/invest/recreation/recmodel_client.py:56 +msgid "A spatial file to use as a predictor." +msgstr "Un archivo espacial para usar como predictor." + +#: src/natcap/invest/recreation/recmodel_client.py:63 +#, fuzzy +msgid "The type of predictor file provided in the 'path' column." +msgstr "El tipo de archivo predictor proporcionado en la columna \"path\"." + +#: src/natcap/invest/recreation/recmodel_client.py:66 +#, fuzzy +msgid "" +"Predictor is a raster. Metric is the mean of values within the AOI grid " +"cell or polygon." +msgstr "" +"El predictor es un ráster. La métrica es la media de los valores dentro " +"de la celda o polígono de la cuadrícula del ADI." + +#: src/natcap/invest/recreation/recmodel_client.py:70 +#, fuzzy +msgid "" +"Predictor is a raster. Metric is the sum of values within the AOI grid " +"cell or polygon." +msgstr "" +"El predictor es un ráster. La métrica es la suma de los valores dentro de" +" la celda de la cuadrícula del ADI o del polígono." + +#: src/natcap/invest/recreation/recmodel_client.py:74 +#, fuzzy +msgid "" +"Predictor is a point vector. Metric is the number of points within each " +"AOI grid cell or polygon." +msgstr "" +"El predictor es un vector de puntos. La métrica es el número de puntos " +"dentro de cada celda de la cuadrícula o polígono del ADI." + +#: src/natcap/invest/recreation/recmodel_client.py:78 +#, fuzzy +msgid "" +"Predictor is a point vector. Metric is the Euclidean distance between the" +" centroid of each AOI grid cell and the nearest point in this layer." +msgstr "" +"El predictor es un vector de puntos. La métrica es la distancia " +"euclidiana entre el centro de cada celda de la cuadrícula ADI y el punto " +"más cercano de esta capa." + +#: src/natcap/invest/recreation/recmodel_client.py:83 +#, fuzzy +msgid "" +"Predictor is a line vector. Metric is the total length of the lines that " +"fall within each AOI grid cell." +msgstr "" +"El predictor es un vector de líneas. La métrica es la longitud total de " +"las líneas que caen dentro de cada celda de la cuadrícula ADI." + +#: src/natcap/invest/recreation/recmodel_client.py:87 +#, fuzzy +msgid "" +"Predictor is a polygon vector. Metric is the area of overlap between the " +"polygon and each AOI grid cell." +msgstr "" +"El predictor es un vector de polígonos. La métrica es el área de " +"solapamiento entre el polígono y cada celda de la cuadrícula ADI." + +#: src/natcap/invest/recreation/recmodel_client.py:91 +#, fuzzy +msgid "" +"Predictor is a polygon vector. Metric is the percentage (0-100) of " +"overlapping area between the polygon and each AOI grid cell." +msgstr "" +"El predictor es un vector de polígonos. La métrica es el porcentaje " +"(0-100) del área de superposición entre el polígono y cada celda de la " +"cuadrícula ADI." + +#: src/natcap/invest/recreation/recmodel_client.py:110 +msgid "Map of area(s) over which to run the model." +msgstr "Mapa de la(s) zona(s) sobre la(s) que se va a ejecutar el modelo." + +#: src/natcap/invest/recreation/recmodel_client.py:115 +msgid "FQDN to a recreation server. If not provided, a default is assumed." +msgstr "" +"FQDN a un servidor de recreación. Si no se proporciona, se asume un " +"valor por defecto." + +#: src/natcap/invest/recreation/recmodel_client.py:118 +#, fuzzy +msgid "hostname" +msgstr "nombre de host" + +#: src/natcap/invest/recreation/recmodel_client.py:125 +#, fuzzy +msgid "the port on ``hostname`` to use for contacting the recreation server." +msgstr "" +"el puerto en ``hostname`` a utilizar para contactar con el servidor de " +"recreación." + +#: src/natcap/invest/recreation/recmodel_client.py:128 +msgid "port" +msgstr "puerto" + +#: src/natcap/invest/recreation/recmodel_client.py:134 +msgid "" +"Year at which to start photo user-day calculations. Calculations start on" +" the first day of the year. Year must be in the range 2005 - 2017, and " +"must be less than or equal to the End Year." +msgstr "" +"Año en el que se inician los cálculos de los días de usuario de las " +"fotos. Los cálculos comienzan el primer día del año. El año debe estar en" +" el rango 2005 - 2017, y debe ser menor o igual que el año final." + +#: src/natcap/invest/recreation/recmodel_client.py:139 +msgid "start year" +msgstr "año de inicio" + +#: src/natcap/invest/recreation/recmodel_client.py:145 +msgid "" +"Year at which to end photo user-day calculations. Calculations continue " +"through the last day of the year. Year must be in the range 2005 - 2017, " +"and must be greater than or equal to the Start Year." +msgstr "" +"Año en el que se terminan los cálculos de los días de uso de las fotos. " +"Los cálculos continúan hasta el último día del año. El año debe estar en " +"el rango 2005 - 2017, y debe ser mayor o igual que el año de inicio." + +#: src/natcap/invest/recreation/recmodel_client.py:150 +msgid "end year" +msgstr "año final" + +#: src/natcap/invest/recreation/recmodel_client.py:155 +#, fuzzy +msgid "" +"Divide the AOI polygons into equal-sized grid cells, and compute results " +"for those cells instead of the original polygons." +msgstr "" +"Divida los polígonos del ADI en celdas de cuadrícula de igual tamaño y " +"calcule los resultados para esas celdas en lugar de los polígonos " +"originales." + +# Check English +#: src/natcap/invest/recreation/recmodel_client.py:159 +#, fuzzy +msgid "grid the AOI" +msgstr "cuadrícula de la AOI" + +#: src/natcap/invest/recreation/recmodel_client.py:164 +msgid "square" +msgstr "cuadrado" + +#: src/natcap/invest/recreation/recmodel_client.py:165 +msgid "hexagon" +msgstr "hexágono" + +#: src/natcap/invest/recreation/recmodel_client.py:168 +#, fuzzy +msgid "" +"The shape of grid cells to make within the AOI polygons. Required if Grid" +" AOI is selected." +msgstr "" +"La forma de las celdas de la cuadrícula a realizar dentro de los " +"polígonos de la ADI. Se requiere si se selecciona Grilla de ADI ." + +#: src/natcap/invest/recreation/recmodel_client.py:171 +msgid "grid type" +msgstr "tipo de cuadrícula" + +#: src/natcap/invest/recreation/recmodel_client.py:178 +#, fuzzy +msgid "" +"Size of grid cells to make, measured in the projection units of the AOI. " +"If the Grid Type is 'square', this is the length of each side of the " +"square. If the Grid Type is 'hexagon', this is the hexagon's maximal " +"diameter." +msgstr "" +"Tamaño de las celdas de la cuadrícula a realizar, medido en las unidades " +"de proyección del ADI. Si el tipo de cuadrícula es \"cuadrado\", es la " +"longitud de cada lado del cuadrado. Si el tipo de cuadrícula es " +"\"hexágono\", es el diámetro máximo del hexágono." + +#: src/natcap/invest/recreation/recmodel_client.py:183 +msgid "cell size" +msgstr "tamaño de la celda" + +#: src/natcap/invest/recreation/recmodel_client.py:188 +msgid "" +"Run the regression model using the predictor table and scenario table, if" +" provided." +msgstr "" +"Ejecute el modelo de regresión utilizando la tabla de predictores y la " +"tabla de escenarios, si se proporciona." + +#: src/natcap/invest/recreation/recmodel_client.py:191 +msgid "compute regression" +msgstr "calcular la regresión" + +#: src/natcap/invest/recreation/recmodel_client.py:198 +msgid "" +"A table that maps predictor IDs to spatial files and their predictor " +"metric types. The file paths can be absolute or relative to the table." +msgstr "" +"Una tabla que asigna los ID de los predictores a los archivos espaciales " +"y a sus tipos de métricas de predicción. Las rutas de los archivos pueden" +" ser absolutas o relativas a la tabla." + +#: src/natcap/invest/recreation/recmodel_client.py:202 +msgid "predictor table" +msgstr "tabla de predicción" + +#: src/natcap/invest/recreation/recmodel_client.py:209 +msgid "" +"A table of future or alternative scenario predictors. Maps IDs to files " +"and their types. The file paths can be absolute or relative to the table." +msgstr "" +"Una tabla de predictores de escenarios futuros o alternativos. Asigna los" +" ID a los archivos y sus tipos. Las rutas de los archivos pueden ser " +"absolutas o relativas a la tabla." + +#: src/natcap/invest/recreation/recmodel_client.py:213 +msgid "scenario predictor table" +msgstr "tabla de predicción de escenarios" + +#: src/natcap/invest/recreation/recmodel_client.py:218 +msgid "Copy of the the AOI vector with aggregate attributes added." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:223 +msgid "The average photo-user-days per year" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:229 +msgid "The average photo-user-days for each month." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:237 +msgid "Table of monthly photo-user-days." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:242 +#, fuzzy +msgid "Polygon ID" +msgstr "POLYGON" + +#: src/natcap/invest/recreation/recmodel_client.py:245 +msgid "Total photo-user-days counted in each cell in the given month." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:255 +msgid "AOI polygons with their corresponding predictor attributes." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:262 +#: src/natcap/invest/recreation/recmodel_client.py:287 +msgid "Predictor attribute value for each polygon." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:269 +msgid "" +"This is a text file output of the regression analysis. It includes " +"estimates for each predictor variable. It also contains a “server id " +"hash” value which can be used to correlate the PUD result with the data " +"available on the PUD server. If these results are used in publication " +"this hash should be included with the results for reproducibility." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:279 +msgid "" +"AOI polygons with their corresponding predictor attributes in the " +"scenario." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:293 +msgid "The estimated PUD_YR_AVG per polygon." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:301 +msgid "Copy of the input AOI, gridded if applicable." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:307 +msgid "Compressed AOI" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:310 +msgid "aggregated predictor values within each polygon" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:314 +#, fuzzy +msgid "Predictor estimates" +msgstr "tabla de predicción" + +#: src/natcap/invest/recreation/recmodel_client.py:317 +msgid "Compressed photo-user-day data" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:319 +msgid "Pickled dictionary mapping FIDs to shapely geometries" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:326 +msgid "aggregated scenario predictor values within each polygon" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:333 +msgid "Server version info" +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:66 +msgid "features impacting scenic quality" +msgstr "características que afectan a la calidad del paisaje" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:74 +msgid "" +"Maximum length of the line of sight originating from a viewpoint. The " +"value can either be positive (preferred) or negative (kept for backwards " +"compatibility), but is converted to a positive number. If this field is " +"not provided, the model will include all pixels in the DEM in the " +"visibility analysis. RADIUS preferred, but may also be called RADIUS2 for" +" backwards compatibility." +msgstr "" +"Longitud máxima de la línea de visión originada por un punto de vista. El" +" valor puede ser positivo (preferido) o negativo (se mantiene por " +"compatibilidad con versiones anteriores), pero se convierte en un número " +"positivo. Si no se proporciona este campo, el modelo incluirá todos los " +"píxeles del MDE en el análisis de visibilidad. Se prefiere RADIUS, pero " +"también puede llamarse RADIUS2 por compatibilidad con versiones " +"anteriores." + +# Not sure how to translate viewshed +#: src/natcap/invest/scenic_quality/scenic_quality.py:87 +#, fuzzy +msgid "" +"Viewshed importance coefficient. If this field is provided, the values " +"are used to weight each feature's viewshed impacts. If not provided, all " +"viewsheds are equally weighted with a weight of 1." +msgstr "" +"Coeficiente de importancia de la vista. Si se proporciona este campo, los" +" valores se utilizan para ponderar los impactos de las vistas de cada " +"característica. Si no se proporciona, todas las vistas se ponderan por " +"igual con un peso de 1." + +#: src/natcap/invest/scenic_quality/scenic_quality.py:96 +msgid "" +"Viewpoint height, the elevation above the ground of each feature. If this" +" field is not provided, defaults to 0." +msgstr "" +"Altura del punto de vista, la elevación sobre el suelo de cada " +"característica. Si no se proporciona este campo, el valor predeterminado " +"es 0." + +#: src/natcap/invest/scenic_quality/scenic_quality.py:101 +msgid "" +"Map of locations of objects that negatively affect scenic quality. This " +"must have the same projection as the DEM." +msgstr "" +"Mapa de ubicación de los objetos que afectan negativamente a la calidad " +"del paisaje. Debe tener la misma proyección que el MDE." + +#: src/natcap/invest/scenic_quality/scenic_quality.py:111 +msgid "refractivity coefficient" +msgstr "coeficiente de refractividad" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:113 +msgid "" +"The refractivity coefficient corrects for the curvature of the earth and " +"refraction of visible light in air." +msgstr "" +"El coeficiente de refracción corrige la curvatura de la tierra y la " +"refracción de la luz visible en el aire." + +#: src/natcap/invest/scenic_quality/scenic_quality.py:124 +msgid "Valuation function" +msgstr "Función de valoración" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:128 +msgid "linear: a + bx" +msgstr "lineal: a + bx" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:129 +msgid "logarithmic: a + b log(x+1)" +msgstr "logarítmico: a + b log(x+1)" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:131 +msgid "exponential: a * e^(-bx)" +msgstr "exponencial: a * e^(-bx)" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:133 +msgid "" +"Valuation function used to calculate the visual impact of each feature, " +"given distance from the feature 'x' and parameters 'a' and 'b'." +msgstr "" +"Función de valoración utilizada para calcular el impacto visual de cada " +"característica, dada la distancia de la característica \"x\" y los " +"parámetros \"a\" y \"b\"." + +#: src/natcap/invest/scenic_quality/scenic_quality.py:139 +msgid "coefficient a" +msgstr "coeficiente a" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:143 +msgid "First coefficient ('a') used by the valuation function" +msgstr "Primer coeficiente ('a') utilizado por la función de valoración" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:146 +msgid "coefficient b" +msgstr "coeficiente b" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:150 +msgid "Second coefficient ('b') used by the valuation function" +msgstr "Segundo coeficiente ('b') utilizado por la función de valoración" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:153 +msgid "maximum valuation radius" +msgstr "radio máximo de valoración" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:158 +msgid "" +"Valuation will only be computed for cells that fall within this radius of" +" a feature impacting scenic quality." +msgstr "" +"La valoración solo se calculará para las celdas que se encuentren dentro " +"de este radio de un elemento que afecte a la calidad del paisaje." + +#: src/natcap/invest/scenic_quality/scenic_quality.py:168 +msgid "Map of visual quality classified into quartiles." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:173 +msgid "" +"This raster layer contains the weighted sum of all visibility rasters. If" +" no weight column is provided in the structures point vector, this raster" +" will represent a count of the number of structure points that are " +"visible from each pixel." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:177 +msgid "" +"This raster layer contains the weighted sum of the valuation rasters " +"created for each point." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:186 +msgid "" +"This vector is the AOI, reprojected to the DEM’s spatial reference and " +"projection." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:191 +msgid "" +"This raster layer is a version of the DEM that has been clipped and " +"masked to the AOI and tiled. This is the DEM file that is used for the " +"viewshed analysis." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:195 +msgid "Copy of the structures vector, clipped to the AOI extent." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:201 +msgid "" +"Copy of the structures vector, reprojected to the DEM’s spatial reference" +" and projection." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:206 +msgid "" +"The calculated value of the viewshed amenity/disamenity given the " +"distances of pixels from the structure's viewpoint, the weight of the " +"viewpoint, the valuation function, and the a and b coefficients. The " +"viewshed’s value is only evaluated for visible pixels." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:210 +msgid "" +"Map of visibility for a given structure's viewpoint. This raster has " +"pixel values of 0 (not visible), 1 (visible), or nodata (where the DEM is" +" nodata)." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:54 +msgid "" +"Map of rainfall erosivity, reflecting the intensity and duration of " +"rainfall in the area of interest." +msgstr "" +"Mapa de erosividad pluvial, que refleja la intensidad y duración de las " +"lluvias en la zona de interés." + +#: src/natcap/invest/sdr/sdr.py:57 +msgid "erosivity" +msgstr "erosividad" + +#: src/natcap/invest/sdr/sdr.py:65 +msgid "" +"Map of soil erodibility, the susceptibility of soil particles to " +"detachment and transport by rainfall and runoff." +msgstr "" +"Mapa de erodabilidad del suelo, la susceptibilidad de las partículas del " +"suelo al desprendimiento y al transporte por la lluvia y la escorrentía." + +#: src/natcap/invest/sdr/sdr.py:69 +msgid "soil erodibility" +msgstr "erosionabilidad del suelo" + +#: src/natcap/invest/sdr/sdr.py:83 +msgid "" +"Map of the boundaries of the watershed(s) over which to aggregate " +"results. Each watershed should contribute to a point of interest where " +"water quality will be analyzed." +msgstr "" +"Mapa de los límites de la(s) cuenca(s) sobre la(s) que se van a agregar " +"los resultados. Cada cuenca debe contribuir a un punto de interés en el " +"que se analizará la calidad del agua." + +#: src/natcap/invest/sdr/sdr.py:87 +msgid "Watersheds" +msgstr "Cuencas hidrográficas" + +#: src/natcap/invest/sdr/sdr.py:96 +msgid "Cover-management factor for the USLE" +msgstr "Factor de gestión de la cubierta para la USLE" + +#: src/natcap/invest/sdr/sdr.py:99 +msgid "Support practice factor for the USLE" +msgstr "Factor de práctica de apoyo para la USLE" + +#: src/natcap/invest/sdr/sdr.py:101 +msgid "" +"A table mapping each LULC code to biophysical properties of that LULC " +"class. All values in the LULC raster must have corresponding entries in " +"this table." +msgstr "" +"Una tabla que asigna cada código LULC a las propiedades biofísicas de esa" +" clase LULC. Todos los valores de la trama LULC deben tener los inputs " +"correspondientes en esta tabla." + +#: src/natcap/invest/sdr/sdr.py:111 +msgid "Borselli k parameter." +msgstr "Parámetro k de Borselli." + +#: src/natcap/invest/sdr/sdr.py:116 +msgid "The maximum SDR value that a pixel can have." +msgstr "El valor máximo de SDR que puede tener un píxel." + +#: src/natcap/invest/sdr/sdr.py:117 +msgid "maximum SDR value" +msgstr "valor máximo de SDR" + +#: src/natcap/invest/sdr/sdr.py:122 +msgid "Borselli IC0 parameter." +msgstr "Parámetro Borselli IC0." + +#: src/natcap/invest/sdr/sdr.py:123 +msgid "Borselli IC0 parameter" +msgstr "Parámetro Borselli IC0" + +#: src/natcap/invest/sdr/sdr.py:129 +msgid "" +"The maximum allowed value of the slope length parameter (L) in the LS " +"factor." +msgstr "" +"El valor máximo permitido del parámetro de longitud de la pendiente (L) " +"en el factor LS." + +#: src/natcap/invest/sdr/sdr.py:132 +msgid "maximum l value" +msgstr "valor máximo de l" + +#: src/natcap/invest/sdr/sdr.py:138 +msgid "" +"Map of locations of artificial drainages that drain to the watershed. " +"Pixels with 1 are drainages and are treated like streams. Pixels with 0 " +"are not drainages." +msgstr "" +"Mapa de las ubicaciones de los drenajes artificiales que drenan a la " +"cuenca. Los píxeles con 1 son drenajes y se tratan como corrientes. Los " +"píxeles con 0 no son drenajes." + +#: src/natcap/invest/sdr/sdr.py:142 +msgid "drainages" +msgstr "drenajes" + +#: src/natcap/invest/sdr/sdr.py:229 +#, fuzzy +msgid "" +"CP factor derived by mapping usle_c and usle_p from the biophysical table" +" to the LULC raster." +msgstr "" +"Una tabla que relaciona cada código LULC del mapa LULC con los datos " +"biofísicos de esa clase LULC." + +#: src/natcap/invest/sdr/sdr.py:235 +msgid "Downslope factor of the index of connectivity (Eq. (74))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:240 +msgid "Upslope factor of the index of connectivity (Eq. (73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:245 +msgid "" +"Sediment downslope deposition, the amount of sediment from a given pixel " +"that does not reach a stream (Eq. (78))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:254 +msgid "" +"Map of sediment flux for sediment that does not reach the stream (Eq. " +"(81))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:265 +msgid "Index of connectivity (Eq. (70))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:272 +msgid "LS factor for USLE (Eq. (69))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:280 +msgid "" +"Flow accumulation weighted by the thresholded slope. Used in calculating " +"s_bar." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:289 +msgid "" +"Mean thresholded slope gradient of the upslope contributing area (in eq. " +"(73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:298 +#, fuzzy +msgid "Sediment delivery ratio (Eq. (75))" +msgstr "Tasa de suministro de sedimentos" + +#: src/natcap/invest/sdr/sdr.py:303 +msgid "" +"Percent slope, thresholded to be no less than 0.005 and no greater than 1" +" (eq. (71)). 1 is equivalent to a 45 degree slope." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:310 +msgid "" +"Flow accumulation weighted by the thresholded cover-management factor. " +"Used in calculating w_bar." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:319 +msgid "" +"Mean thresholded cover-management factor for upslope contributing area " +"(in eq. (73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:325 +msgid "" +"Cover-management factor derived by mapping usle_c from the biophysical " +"table to the LULC raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:331 +msgid "Cover-management factor thresholded to be no less than 0.001 (eq. (72))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:337 +msgid "Average aspect weighted by flow direction (in eq. (69))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:342 +msgid "" +"Map of which pixels drain to a stream. A value of 1 means that at least " +"some of the runoff from that pixel drains to a stream in stream.tif. A " +"value of 0 means that it does not drain at all to any stream in " +"stream.tif." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:351 +msgid "" +"Inverse of the thresholded cover-management factor times the thresholded " +"slope (in eq. (74))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:357 +msgid "Copy of the input DEM, clipped to the extent of the other raster inputs." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:366 +msgid "" +"Copy of the input drainage map, clipped to the extent of the other raster" +" inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:373 +msgid "" +"Copy of the input erodibility map, clipped to the extent of the other " +"raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:383 +msgid "" +"Copy of the input erosivity map, clipped to the extent of the other " +"raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:393 +msgid "" +"Copy of the input Land Use Land Cover map, clipped to the extent of the " +"other raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:400 +msgid "" +"A raster aligned to the DEM and clipped to the extent of the other raster" +" inputs. Pixel values indicate where a nodata value exists in the stack " +"of aligned rasters (pixel value of 0), or if all values in the stack of " +"rasters at this pixel location are valid." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:410 +msgid "A copy of the aligned DEM, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:418 +msgid "A copy of the aligned drainage map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:425 +msgid "A copy of the aligned erodibility map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:435 +msgid "A copy of the aligned erosivity map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:444 +msgid "" +"A copy of the aligned Land Use Land Cover map, masked using the mask " +"raster." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:53 +msgid "" +"Twelve files, one for each month. File names must end with the month " +"number (1-12). For example, the filenames 'et0_1.tif' " +"'evapotranspiration1.tif' are both valid for the month of January." +msgstr "" +"Doce archivos, uno por cada mes. Los nombres de los archivos deben " +"terminar con el número del mes (1-12). Por ejemplo, los nombres de " +"archivo \"et0_1.tif\" \"evapotranspiración1.tif\" son válidos para el mes" +" de enero." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:62 +msgid "" +"Directory containing maps of reference evapotranspiration for each month." +" Only .tif files should be in this folder (no .tfw, .xml, etc files)." +msgstr "" +"Directorio que contiene los mapas de evapotranspiración de referencia " +"para cada mes. En esta carpeta solo debe haber archivos .tif (no hay " +"archivos .tfw, .xml, etc.)." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:66 +msgid "ET0 directory" +msgstr "Directorio ET0" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:74 +msgid "" +"Twelve files, one for each month. File names must end with the month " +"number (1-12). For example, the filenames 'precip_1.tif' and " +"'precip1.tif' are both valid names for the month of January." +msgstr "" +"Doce archivos, uno por cada mes. Los nombres de los archivos deben " +"terminar con el número del mes (1-12). Por ejemplo, los nombres de " +"archivo 'precip_1.tif' y 'precip1.tif' son ambos válidos para el mes de " +"enero." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:82 +msgid "" +"Directory containing maps of monthly precipitation for each month. Only " +".tif files should be in this folder (no .tfw, .xml, etc files)." +msgstr "" +"Directorio que contiene los mapas de precipitación mensual para cada mes." +" En esta carpeta solo debe haber archivos .tif (no hay archivos .tfw, " +".xml, etc.)." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:86 +msgid "precipitation directory" +msgstr "directorio de precipitación" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:95 +msgid "" +"All values in this raster MUST have corresponding entries in the " +"Biophysical Table." +msgstr "" +"Todos los valores de este ráster deben tener sus correspondientes inputs " +"en la Tabla Biofísica." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:116 +msgid "" +"Curve number values for each combination of soil group and LULC class. " +"Replace [SOIL_GROUP] with each soil group code A, B, C, D so that there " +"is one column for each soil group. Curve number values must be greater " +"than 0." +msgstr "" +"Valores del número de la curva para cada combinación de grupo de suelos y" +" clase LULC. Sustituya [GRUPO_SUELO] por el código de cada grupo de suelo" +" A, B, C, D para que haya una columna para cada grupo de suelo. Los " +"valores del número de la curva deben ser mayores que 0." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:126 +msgid "" +"Crop/vegetation coefficient (Kc) values for this LULC class in each " +"month. Replace [MONTH] with the numbers 1 to 12 so that there is one " +"column for each month." +msgstr "" +"Valores del coeficiente de cultivo/vegetación (Kc) para esta clase LULC " +"en cada mes. Sustituya [MES] por los números del 1 al 12 para que haya " +"una columna para cada mes." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:133 +msgid "" +"A table mapping each LULC code to biophysical properties of the " +"corresponding LULC class. All values in the LULC raster must have " +"corresponding entries in this table." +msgstr "" +"Una tabla que asigna cada código LULC a las propiedades biofísicas de la " +"clase LULC correspondiente. Todos los valores de la trama LULC deben " +"tener los inputs correspondientes en esta tabla." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:146 +msgid "" +"Values are the numbers 1-12 corresponding to each month, January (1) " +"through December (12)." +msgstr "" +"Los valores son los números del 1 al 12 correspondientes a cada mes, de " +"enero (1) a diciembre (12)." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:153 +msgid "The number of rain events in that month." +msgstr "El número de eventos de lluvia en ese mes." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:159 +#, fuzzy +msgid "" +"A table containing the number of rain events for each month. Required if " +"neither User-Defined Local Recharge nor User-Defined Climate Zones is " +"selected." +msgstr "" +"Una tabla que contiene el número de eventos de lluvia para cada mes. Se " +"requiere si no se selecciona ni Recarga Local Definida por el Usuario ni " +"Zonas Climáticas Definidas por el Usuario." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:163 +msgid "rain events table" +msgstr "tabla de eventos de lluvia" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:168 +msgid "" +"The proportion of upslope annual available local recharge that is " +"available in each month. Required if Use Monthly Alpha Table is not " +"selected." +msgstr "" +"La proporción de la recarga local anual disponible pendiente arriba que " +"está disponible en cada mes. Requerido si no se selecciona la opción de " +"usar la tabla mensual Alpha." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:172 +msgid "alpha_m parameter" +msgstr "parámetro alpha_m" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:176 +msgid "" +"The proportion of the upgradient subsidy that is available for " +"downgradient evapotranspiration." +msgstr "" +"La proporción del subsidio ascendente que está disponible para la " +"evapotranspiración descendente." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:179 +msgid "beta_i parameter" +msgstr "parámetro beta_i" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:183 +msgid "" +"The proportion of pixel local recharge that is available to downgradient " +"pixels." +msgstr "" +"La proporción de la recarga local del píxel que está disponible para los " +"píxeles pendiente abajo." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:186 +msgid "gamma parameter" +msgstr "parámetro gamma" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:190 +msgid "" +"Use user-defined local recharge data instead of calculating local " +"recharge from the other provided data." +msgstr "" +"Utilizar los datos de recarga local definidos por quien usa el modelo en " +"lugar de calcular la recarga local a partir de los otros datos " +"proporcionados." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:193 +msgid "user-defined recharge layer (advanced)" +msgstr "capa de recarga definida por quien usa el modelo (avanzado)" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:203 +msgid "" +"Map of local recharge data. Required if User-Defined Local Recharge is " +"selected." +msgstr "" +"Mapa de datos de recarga local. Se necesita si se selecciona la opción de" +" recarga local definida por quien usa el modelo." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:206 +msgid "local recharge" +msgstr "recarga local" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:210 +msgid "Use user-defined climate zone data in lieu of a global rain events table." +msgstr "" +"Utilizar datos de zonas climáticas definidas por quien usa el modelo en " +"lugar de una tabla global de eventos de lluvia." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:213 +msgid "climate zones (advanced)" +msgstr "zonas climáticas (avanzado)" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:221 +msgid "" +"Climate zone ID numbers, corresponding to the values in the Climate Zones" +" map." +msgstr "" +"Números de identificación de la zona climática, correspondientes a los " +"valores del mapa de las zonas climáticas." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:227 +msgid "" +"The number of rain events that occur in each month in this climate zone. " +"Replace [MONTH] with the month abbreviations: jan, feb, mar, apr, may, " +"jun, jul, aug, sep, oct, nov, dec, so that there is a column for each " +"month." +msgstr "" +"El número de eventos de lluvia que se producen en cada mes en esta zona " +"climática. Sustituya [MES] por las abreviaturas de los meses: ene, feb, " +"mar, abr, may, jun, jul, ago, sep, oct, nov y dic, de modo que haya una " +"columna para cada mes." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:235 +#, fuzzy +msgid "" +"Table of monthly precipitation events for each climate zone. Required if " +"User-Defined Climate Zones is selected." +msgstr "" +"Tabla de eventos de precipitación mensual para cada zona climática. Se " +"requiere si se selecciona Zonas Climáticas Definidas por el Usuario." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:238 +msgid "climate zone table" +msgstr "tabla de zonas climáticas" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:245 +msgid "" +"Map of climate zones. All values in this raster must have corresponding " +"entries in the Climate Zone Table." +msgstr "" +"Mapa de zonas climáticas. Todos los valores de este raster deben tener " +"los inputs correspondientes en la Tabla de Zonas Climáticas." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:248 +msgid "climate zone map" +msgstr "mapa de zonas climáticas" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:252 +msgid "Use montly alpha values instead of a single value for the whole year." +msgstr "" +"Utilizar valores alfa mensuales en lugar de un único valor para todo el " +"año." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:255 +msgid "use monthly alpha table (advanced)" +msgstr "utilizar la tabla alfa mensual (avanzado)" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:264 +msgid "Values are the numbers 1-12 corresponding to each month." +msgstr "Los valores son los números 1-12 correspondientes a cada mes." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:271 +msgid "The alpha value for that month." +msgstr "El valor alfa de ese mes." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:275 +#, fuzzy +msgid "" +"Table of alpha values for each month. Required if Use Monthly Alpha Table" +" is selected." +msgstr "" +"Tabla de valores alfa para cada mes. Es necesaria si se selecciona Usar " +"tabla de alfa mensual." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:278 +msgid "monthly alpha table" +msgstr "tabla alfa mensual" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:283 +msgid "" +"Map of baseflow values, the contribution of a pixel to slow release flow " +"(which is not evapotranspired before it reaches the stream)." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:293 +msgid "" +"Map of B_sum values, the flow through a pixel, contributed by all upslope" +" pixels, that is not evapotranspirated before it reaches the stream." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:303 +#, fuzzy +msgid "Map of curve number values." +msgstr "Mapa de líneas centrales de carreteras" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:310 +#, fuzzy +msgid "Map of available local recharge" +msgstr "recarga local" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:317 +#, fuzzy +msgid "Map of local recharge values" +msgstr "recarga local" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:324 +msgid "" +"Map of total available water, contributed by all upslope pixels, that is " +"available for evapotranspiration by this pixel." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:333 +msgid "" +"Map of cumulative upstream recharge: the flow through a pixel, " +"contributed by all upslope pixels, that is available for " +"evapotranspiration to downslope pixels." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:343 +msgid "Map of quickflow" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:350 +msgid "The total precipitation across all months on this pixel." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:357 +msgid "" +"Map of the values of recharge (contribution, positive or negative), to " +"the total recharge." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:366 +#, fuzzy +msgid "Table of biophysical values for each watershed" +msgstr "Tabla de propiedades biofísicas para cada clase de LULC." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:370 +msgid "Mean local recharge value within the watershed" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:376 +msgid "Total recharge contribution, (positive or negative) within the watershed." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:388 +#, fuzzy +msgid "Map of actual evapotranspiration" +msgstr "Mapa de valores de evapotranspiración." + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:395 +msgid "" +"Map of multiple flow direction. Values are encoded in a binary format and" +" should not be used directly." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:401 +msgid "Maps of monthly quickflow (1 = January… 12 = December)" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:409 +msgid "" +"Stream network map generated from the input DEM and Threshold Flow " +"Accumulation. Values of 1 represent streams, values of 0 are non-stream " +"pixels." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:418 +msgid "Map of the S_i factor derived from CN" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:422 +msgid "Copy of LULC input, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:427 +msgid "Copy of DEM input, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:432 +msgid "Pit filled DEM" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:436 +msgid "" +"Copy of soil groups input, aligned and clipped to match the other spatial" +" inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:443 +msgid "" +"Monthly precipitation rasters, aligned and clipped to match the other " +"spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:447 +msgid "Map of monthly rain events" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:452 +msgid "Monthly ET0 rasters, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:456 +msgid "Map of monthly KC values" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:460 +msgid "" +"Copy of user-defined local recharge input, aligned and clipped to match " +"the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:465 +msgid "" +"Copy of user-defined climate zones raster, aligned and clipped to match " +"the other spatial inputs" +msgstr "" + +#~ msgid "LULC code corresponding to values in the LULC map." +#~ msgstr "Código LULC correspondiente a los valores del mapa LULC." + +#~ msgid "" +#~ "LULC code. Every value in the LULC" +#~ " maps must have a corresponding entry" +#~ " in this column." +#~ msgstr "" +#~ "Código LULC. Cada valor de los " +#~ "mapas LULC debe tener su correspondiente" +#~ " input en esta columna." + +#~ msgid "very high protection" +#~ msgstr "protección muy alta" + +#~ msgid "high protection" +#~ msgstr "protección alta" + +#~ msgid "moderate protection" +#~ msgstr "protección moderada" + +#~ msgid "low protection" +#~ msgstr "protección baja" + +#~ msgid "very low protection" +#~ msgstr "protección muy baja" + +#~ msgid "" +#~ "Code for this LULC class from the" +#~ " LULC map. Every value in the " +#~ "LULC raster must have a corresponding" +#~ " entry in this column." +#~ msgstr "" +#~ "Código de esta clase LULC del mapa" +#~ " LULC. Cada valor de la trama " +#~ "LULC debe tener un input correspondiente" +#~ " en esta columna." + +#~ msgid "Use the predefined GLOBIO LULC map instead of providing the LULC map." +#~ msgstr "" +#~ "Utilice el mapa LULC predefinido de " +#~ "GLOBIO en lugar de proporcionar el " +#~ "mapa LULC." + +#~ msgid "use predefined LULC" +#~ msgstr "utilizar LULC predefinidos" + +#~ msgid "" +#~ "Each LULC code must have a " +#~ "corresponding entry in the biophysical " +#~ "table. Required if Use Predefined GLOBIO" +#~ " LULC is not selected." +#~ msgstr "" +#~ "Cada código LULC debe tener un " +#~ "input correspondiente en la tabla " +#~ "biofísica. Es obligatorio si no se " +#~ "ha seleccionado la opción de utilizar" +#~ " LULC GLOBIO predefinido." + +#~ msgid "LULC code from the LULC map input." +#~ msgstr "Código LULC del input del mapa LULC." + +#~ msgid "Corresponding GLOBIO LULC code." +#~ msgstr "Código LULC GLOBIO correspondiente." + +#~ msgid "" +#~ "A table mapping each LULC code in" +#~ " the LULC raster input to the " +#~ "corresponding GLOBIO LULC code for the" +#~ " class. Required if Use Predefined " +#~ "GLOBIO LULC is not selected." +#~ msgstr "" +#~ "Una tabla que mapea cada código " +#~ "LULC en el input del ráster LULC" +#~ " al correspondiente código LULC GLOBIO " +#~ "para la clase. Es necesario si no" +#~ " se selecciona la opción Usar LULC" +#~ " GLOBIO predefinida." + +#~ msgid "LULC to GLOBIO LULC Table" +#~ msgstr "Tabla LULC a LULC GLOBIO " + +#~ msgid "" +#~ "Maps of the location of infrastructure." +#~ " For rasters, any valid value greater" +#~ " than zero indicates the presence of" +#~ " infrastrucutre. For vectors, any " +#~ "geometries indicate the presence of " +#~ "infrastructure." +#~ msgstr "" +#~ "Mapas de la ubicación de las " +#~ "infraestructuras. Para los rásters, cualquier" +#~ " valor válido superior a cero indica" +#~ " la presencia de infraestructuras. Para " +#~ "los vectores, cualquier geometría indica " +#~ "la presencia de infraestructuras." + +#~ msgid "" +#~ "Directory containing raster and/or vector " +#~ "map(s) any forms of infrastructure to" +#~ " consider in the MSA calculation." +#~ msgstr "" +#~ "Directorio que contiene mapa(s) ráster " +#~ "y/o vectorial(es) cualquier forma de " +#~ "infraestructura a considerar en el " +#~ "cálculo de la abundancia media de " +#~ "especies (AME)." + +#~ msgid "infrastructure directory" +#~ msgstr "directorio de infraestructuras" + +# Not sure about translating the selected item +#~ msgid "" +#~ "Map of the proportion of each " +#~ "pixel that is pasture. Required if " +#~ "Use Predefined GLOBIO LULC is not " +#~ "selected." +#~ msgstr "" +#~ "Mapa de la proporción de cada " +#~ "píxel que es pasto. Es necesario " +#~ "si no se selecciona la opción de" +#~ " usar LULC GLOBIO predefinido." + +#~ msgid "pasture" +#~ msgstr "pasto" + +#~ msgid "potential vegetation" +#~ msgstr "vegetación potencial" + +# Idem +#~ msgid "" +#~ "Map of potential vegetation classes from" +#~ " Ramankutty and Foley (1999). Required " +#~ "if Use Predefined GLOBIO LULC is " +#~ "not selected." +#~ msgstr "" +#~ "Mapa de clases de vegetación potencial" +#~ " de Ramankutty y Foley (1999). Es " +#~ "necesario si no se selecciona la " +#~ "opción de usar LULC GLOBIO predefinido." + +# Idem +#~ msgid "" +#~ "Areas in the Pasture map with a" +#~ " pasture proportion greater than or " +#~ "equal to this threshold are considered" +#~ " grassland or livestock grazing areas. " +#~ "Required if Use Predefined GLOBIO LULC" +#~ " is not selected." +#~ msgstr "" +#~ "Las áreas en el mapa de pastos " +#~ "con una proporción de pastos mayor " +#~ "o igual a este umbral se " +#~ "consideran áreas de pastizales o de " +#~ "pastoreo de ganado. Es obligatorio si" +#~ " no se selecciona la opción de " +#~ "utilizar LULC GLOBIO predefinido." + +#~ msgid "pasture threshold" +#~ msgstr "umbral de pastoreo" + +#~ msgid "Proportion of total agriculture that is intensive. " +#~ msgstr "Proporción de la agricultura total que es intensiva. " + +#~ msgid "proportion of intensified agriculture" +#~ msgstr "proporción de agricultura intensificada" + +# Check English (ragmentation) +#~ msgid "" +#~ "Forest ragmentation quality index threshold" +#~ " below which an area is classified" +#~ " as secondary forest. Areas with FFQI" +#~ " greater than or equal to this " +#~ "threshold are classified as primary " +#~ "forest. Required if Use Predefined " +#~ "GLOBIO LULC is not selected." +#~ msgstr "" +#~ "Umbral del índice de calidad de " +#~ "fragmentación forestal por debajo del " +#~ "cual una zona se clasifica como " +#~ "bosque secundario. Las áreas con un " +#~ "ICFF mayor o igual a este umbral" +#~ " se clasifican como bosque primario. " +#~ "Obligatorio si no se selecciona la " +#~ "opción de utilizar LULC GLOBIO " +#~ "predefinido ." + +#~ msgid "primary threshold" +#~ msgstr "umbral primario" + +#~ msgid "" +#~ "This MSA value represents infrastructure " +#~ "impacts on primary vegetation. The value" +#~ " in the 'value' column is a " +#~ "distance range in meters." +#~ msgstr "" +#~ "Este valor AME representa los impactos" +#~ " de la infraestructura en la " +#~ "vegetación primaria. El valor de la " +#~ "columna \"valor\" es un rango de " +#~ "distancia en metros." + +#~ msgid "" +#~ "This MSA value represents infrastructure " +#~ "impacts on non-primary vegetation. The" +#~ " value in the 'value' column is " +#~ "a distance range in meters." +#~ msgstr "" +#~ "Este valor AME representa los impactos" +#~ " de la infraestructura en la " +#~ "vegetación no primaria. El valor de " +#~ "la columna \"valor\" es un rango " +#~ "de distancia en metros." + +#~ msgid "" +#~ "This MSA value represents fragmentation " +#~ "impacts. The value in the 'value' " +#~ "column is an FFQI range." +#~ msgstr "" +#~ "Este valor AME representa los impactos" +#~ " de la fragmentación. El valor de " +#~ "la columna \"valor\" es un rango " +#~ "FFQI." + +#~ msgid "" +#~ "This MSA value represents land-use " +#~ "impacts. The value in the 'value' " +#~ "column is one of the GLOBIO-" +#~ "recognized LULC codes." +#~ msgstr "" +#~ "Este valor AME representa los impactos" +#~ " del uso de la tierra. El valor" +#~ " de la columna \"valor\" es uno " +#~ "de los códigos LULC reconocidos por " +#~ "GLOBIO." + +#~ msgid "" +#~ "Indicates a number or range of a" +#~ " bin. This may be a single " +#~ "number e.g. 1000, a range (two " +#~ "numbers separated by a hyphen e.g. " +#~ "1000-2000), or an upper or lower " +#~ "bound (a number preceded by > or" +#~ " < e.g. <5" +#~ msgstr "" +#~ "Indica un número o un rango de " +#~ "una intevalo. Puede ser un solo " +#~ "número, por ejemplo, 1000, un rango " +#~ "(dos números separados por un guion, " +#~ "por ejemplo, 1000-2000), o un límite " +#~ "superior o inferior (un número precedido" +#~ " por > o <, por ejemplo, <5" + +#~ msgid "" +#~ "MSA value for the MSA type " +#~ "specified in the 'msa_type' column, when" +#~ " the impact value is within the " +#~ "range given in the 'value' column." +#~ msgstr "" +#~ "Valor de AME para el tipo de " +#~ "especificado en la columna \"msa_type\", " +#~ "cuando el valor de impacto está " +#~ "dentro del rango dado en la " +#~ "columna \"value\"." + +#~ msgid "" +#~ "Table that sets the MSA values for" +#~ " each impact driver and each range" +#~ " of impact values." +#~ msgstr "" +#~ "Tabla que establece los valores AME " +#~ "para cada motor de impacto y cada" +#~ " rango de valores de impacto." + +#~ msgid "MSA Parameter Table" +#~ msgstr "Tabla de parámetros AME" + +#~ msgid "" +#~ "Predefined GLOBIO LULC map using the " +#~ "standard GLOBIO classification scheme and " +#~ "codes. Required if Use Predefined GLOBIO" +#~ " LULC is selected." +#~ msgstr "" +#~ "Mapa LULC predefinido de GLOBIO que " +#~ "utiliza el esquema de clasificación y" +#~ " los códigos estándar de GLOBIO. Es" +#~ " necesario si se selecciona la opción" +#~ " de usar LULC GLOBIO predefinido." + +#~ msgid "GLOBIO Classified Land Use" +#~ msgstr "Uso del suelo clasificado por GLOBIO" + +#~ msgid "" +#~ "The column '{column_name}' was not found" +#~ " in the Threat Data table for " +#~ "the corresponding input LULC scenario." +#~ msgstr "" +#~ "La columna '{column_name}' no se " +#~ "encontró en la tabla de Datos de" +#~ " Amenazas para el escenario LULC de" +#~ " input correspondiente." + +#~ msgid "" +#~ "Map of the threat's distribution in " +#~ "the future scenario. Each pixel value" +#~ " is the relative intensity of the " +#~ "threat at that location. Required if " +#~ "Future LULC is provided." +#~ msgstr "" +#~ "Mapa de la distribución de la " +#~ "amenaza en el escenario futuro. El " +#~ "valor de cada píxel es la " +#~ "intensidad relativa de la amenaza en " +#~ "ese lugar. Se requiere si se " +#~ "proporciona el LULC futuro." + +#~ msgid "LULC codes corresponding to those in the LULC rasters." +#~ msgstr "Códigos LULC correspondientes a los de los rásters LULC." + +#~ msgid "GLOBIO" +#~ msgstr "GLOBIO" + +#~ msgid "LULC code representing this class in the LULC raster." +#~ msgstr "Código LULC que representa esta clase en el ráster LULC." + +#~ msgid "Map of land use/land cover codes." +#~ msgstr "Mapa de códigos de uso y cobertura del suelo." + +#~ msgid "POINT" +#~ msgstr "POINT" + +#~ msgid "MULTIPOINT" +#~ msgstr "MULTIPOINT" + +#~ msgid "LINESTRING" +#~ msgstr "LINESTRING" + +#~ msgid "MULTILINESTRING" +#~ msgstr "MULTILINESTRING" + +#~ msgid "MULTIPOLYGON" +#~ msgstr "MULTIPOLYGON" + +#~ msgid "LULC code corresponding to those in the LULC map." +#~ msgstr "Código LULC correspondiente a los del mapa LULC." + +#~ msgid "LULC codes matching those in the LULC map." +#~ msgstr "Códigos LULC que coinciden con los del mapa LULC." + +#~ msgid "File could not be opened as a CSV or Excel file." +#~ msgstr "El archivo no pudo abrirse como un archivo CSV o Excel." + +#~ msgid "File could not be opened as a CSV. File must be encoded as a UTF-8 CSV." +#~ msgstr "" +#~ "El archivo no se ha podido abrir" +#~ " como CSV. El archivo debe estar " +#~ "codificado como un CSV UTF-8." + +#~ msgid "Bounding boxes do not intersect: {bboxes}" +#~ msgstr "Las cajas delimitadoras no se cruzan: {bboxes}" + +#~ msgid "Maximum capacity for device." +#~ msgstr "Capacidad máxima del dispositivo." + +#~ msgid "" +#~ "Upper limit of wave height for " +#~ "device operation. The device shuts down" +#~ " when waves are higher than this." +#~ msgstr "" +#~ "Límite superior de la altura de " +#~ "las olas para el funcionamiento del " +#~ "dispositivo. El dispositivo se apaga " +#~ "cuando las olas son más altas que" +#~ " esto." + +#~ msgid "" +#~ "Upper limit of wave period for " +#~ "device operation. The device shuts down" +#~ " when the wave period is longer " +#~ "than this." +#~ msgstr "" +#~ "Límite superior del periodo de onda " +#~ "para el funcionamiento del aparato. El" +#~ " dispositivo se apaga cuando el " +#~ "periodo de onda es mayor que este." + +#~ msgid "Maximum capacity of the device." +#~ msgstr "Capacidad máxima del dispositivo." + +#~ msgid "Capital cost per device installed." +#~ msgstr "Costo de capital por dispositivo instalado." + +#~ msgid "Cost of mooring lines." +#~ msgstr "Costo de los cabos de amarre." + +#~ msgid "Cost of underwater cable." +#~ msgstr "Costo del cable submarino." + +#~ msgid "Cost of overland transmission lines." +#~ msgstr "Costo de las líneas de transmisión terrestre." + +#~ msgid "Operating and maintenance cost." +#~ msgstr "Costo de funcionamiento y mantenimiento." + +#~ msgid "Price of electricity." +#~ msgstr "Precio de la electricidad." + +#~ msgid "Discount rate." +#~ msgstr "Tasa de descuento." + +#~ msgid "Number of slack lines required per machine." +#~ msgstr "Número de líneas de holgura necesarias por máquina." + +#~ msgid "LULC code for this class corresponding to values in the LULC raster." +#~ msgstr "" +#~ "Código LULC para esta clase " +#~ "correspondiente a los valores del ráster" +#~ " LULC." + +#~ msgid "{number} features have a non-integer ws_id field" +#~ msgstr "{number} las características tienen un campo ws_id no entero" + +#~ msgid "Unique identifier for the watershed." +#~ msgstr "Identificador único de la cuenca hidrográfica." + +#~ msgid "LULC code matching those in the LULC raster." +#~ msgstr "Código LULC que coincide con los del ráster LULC." + diff --git a/src/natcap/invest/internationalization/messages.pot b/src/natcap/invest/internationalization/messages.pot index c66761cdcf..720b480c54 100644 --- a/src/natcap/invest/internationalization/messages.pot +++ b/src/natcap/invest/internationalization/messages.pot @@ -1,958 +1,944 @@ # Translations template for InVEST. -# Copyright (C) 2023 Natural Capital Project +# Copyright (C) 2024 Natural Capital Project # This file is distributed under the same license as the InVEST project. -# FIRST AUTHOR , 2023. +# FIRST AUTHOR , 2024. # #, fuzzy msgid "" msgstr "" -"Project-Id-Version: InVEST 3.12.1.post164+gd33ae165f.d20230303\n" -"Report-Msgid-Bugs-To: esoth@stanford.edu\n" -"POT-Creation-Date: 2023-03-03 12:40-0800\n" +"Project-Id-Version: InVEST 3.14.1.post110+g0223b0d05.d20240325\n" +"Report-Msgid-Bugs-To: natcap-software@lists.stanford.edu\n" +"POT-Creation-Date: 2024-03-25 13:25-0700\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.10.3\n" +"Generated-By: Babel 2.14.0\n" -#: src/natcap/invest/annual_water_yield.py:43 -#: src/natcap/invest/forest_carbon_edge_effect.py:113 -#: src/natcap/invest/sdr/sdr.py:73 +#: src/natcap/invest/annual_water_yield.py:92 +#: src/natcap/invest/annual_water_yield.py:186 +msgid "Unique identifier for each subwatershed." +msgstr "" + +#: src/natcap/invest/annual_water_yield.py:101 +#: src/natcap/invest/annual_water_yield.py:170 +msgid "Unique identifier for each watershed." +msgstr "" + +#: src/natcap/invest/annual_water_yield.py:129 +#: src/natcap/invest/forest_carbon_edge_effect.py:115 +#: src/natcap/invest/sdr/sdr.py:74 msgid "All values in this raster must have corresponding entries in the Biophysical Table." msgstr "" -#: src/natcap/invest/annual_water_yield.py:54 +#: src/natcap/invest/annual_water_yield.py:140 msgid "Map of root restricting layer depth, the soil depth at which root penetration is strongly inhibited because of physical or chemical characteristics." msgstr "" -#: src/natcap/invest/annual_water_yield.py:58 +#: src/natcap/invest/annual_water_yield.py:144 msgid "root restricting layer depth" msgstr "" -#: src/natcap/invest/annual_water_yield.py:68 +#: src/natcap/invest/annual_water_yield.py:154 msgid "Map of plant available water content, the fraction of water that can be stored in the soil profile that is available to plants." msgstr "" -#: src/natcap/invest/annual_water_yield.py:72 +#: src/natcap/invest/annual_water_yield.py:158 msgid "plant available water content" msgstr "" -#: src/natcap/invest/annual_water_yield.py:84 -msgid "Unique identifier for each watershed." -msgstr "" - -#: src/natcap/invest/annual_water_yield.py:88 +#: src/natcap/invest/annual_water_yield.py:174 msgid "Map of watershed boundaries, such that each watershed drains to a point of interest where hydropower production will be analyzed." msgstr "" -#: src/natcap/invest/annual_water_yield.py:92 src/natcap/invest/ndr/ndr.py:72 +#: src/natcap/invest/annual_water_yield.py:178 src/natcap/invest/ndr/ndr.py:73 msgid "watersheds" msgstr "" -#: src/natcap/invest/annual_water_yield.py:100 -msgid "Unique identifier for each subwatershed." -msgstr "" - -#: src/natcap/invest/annual_water_yield.py:105 +#: src/natcap/invest/annual_water_yield.py:191 msgid "Map of subwatershed boundaries within each watershed in the Watersheds map." msgstr "" -#: src/natcap/invest/annual_water_yield.py:108 +#: src/natcap/invest/annual_water_yield.py:194 msgid "sub-watersheds" msgstr "" -#: src/natcap/invest/annual_water_yield.py:116 +#: src/natcap/invest/annual_water_yield.py:202 msgid "Code indicating whether the the LULC class is vegetated for the purpose of AET. Enter 1 for all vegetated classes except wetlands, and 0 for all other classes, including wetlands, urban areas, water bodies, etc." msgstr "" -#: src/natcap/invest/annual_water_yield.py:126 +#: src/natcap/invest/annual_water_yield.py:212 msgid "Maximum root depth for plants in this LULC class. Only used for classes with a 'lulc_veg' value of 1." msgstr "" -#: src/natcap/invest/annual_water_yield.py:133 -#: src/natcap/invest/urban_cooling_model.py:63 +#: src/natcap/invest/annual_water_yield.py:219 +#: src/natcap/invest/urban_cooling_model.py:65 msgid "Crop coefficient for this LULC class." msgstr "" -#: src/natcap/invest/annual_water_yield.py:135 +#: src/natcap/invest/annual_water_yield.py:222 msgid "Table of biophysical parameters for each LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "" -#: src/natcap/invest/annual_water_yield.py:139 -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:205 -#: src/natcap/invest/forest_carbon_edge_effect.py:109 -#: src/natcap/invest/ndr/ndr.py:118 src/natcap/invest/pollination.py:116 -#: src/natcap/invest/sdr/sdr.py:103 -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:138 -#: src/natcap/invest/urban_cooling_model.py:56 -#: src/natcap/invest/urban_flood_risk_mitigation.py:76 +#: src/natcap/invest/annual_water_yield.py:226 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:208 +#: src/natcap/invest/forest_carbon_edge_effect.py:111 +#: src/natcap/invest/ndr/ndr.py:120 src/natcap/invest/pollination.py:118 +#: src/natcap/invest/sdr/sdr.py:105 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:137 +#: src/natcap/invest/urban_cooling_model.py:57 +#: src/natcap/invest/urban_flood_risk_mitigation.py:77 msgid "biophysical table" msgstr "" -#: src/natcap/invest/annual_water_yield.py:145 +#: src/natcap/invest/annual_water_yield.py:232 msgid "The seasonality factor, representing hydrogeological characterisitics and the seasonal distribution of precipitation. Values typically range from 1 - 30." msgstr "" -#: src/natcap/invest/annual_water_yield.py:149 +#: src/natcap/invest/annual_water_yield.py:236 msgid "z parameter" msgstr "" -#: src/natcap/invest/annual_water_yield.py:155 +#: src/natcap/invest/annual_water_yield.py:242 msgid "LULC code corresponding to the LULC raster" msgstr "" -#: src/natcap/invest/annual_water_yield.py:159 +#: src/natcap/invest/annual_water_yield.py:246 msgid "Average consumptive water use in this LULC class." msgstr "" -#: src/natcap/invest/annual_water_yield.py:166 +#: src/natcap/invest/annual_water_yield.py:254 msgid "A table of water demand for each LULC class. Each LULC code in the LULC raster must have a corresponding row in this table." msgstr "" -#: src/natcap/invest/annual_water_yield.py:170 +#: src/natcap/invest/annual_water_yield.py:258 msgid "water demand table" msgstr "" -#: src/natcap/invest/annual_water_yield.py:177 +#: src/natcap/invest/annual_water_yield.py:265 msgid "Unique identifier for the hydropower station. This must match the 'ws_id' value for the corresponding watershed in the Watersheds vector. Each watershed in the Watersheds vector must have its 'ws_id' entered in this column." msgstr "" -#: src/natcap/invest/annual_water_yield.py:186 +#: src/natcap/invest/annual_water_yield.py:274 msgid "Turbine efficiency, the proportion of potential energy captured and converted to electricity by the turbine." msgstr "" -#: src/natcap/invest/annual_water_yield.py:193 +#: src/natcap/invest/annual_water_yield.py:281 msgid "The proportion of inflow water volume that is used to generate energy." msgstr "" -#: src/natcap/invest/annual_water_yield.py:200 +#: src/natcap/invest/annual_water_yield.py:288 msgid "The head, measured as the average annual effective height of water behind each dam at the turbine intake." msgstr "" -#: src/natcap/invest/annual_water_yield.py:208 +#: src/natcap/invest/annual_water_yield.py:296 msgid "The price of power produced by the station. Must be in the same currency used in the 'cost' column." msgstr "" -#: src/natcap/invest/annual_water_yield.py:215 +#: src/natcap/invest/annual_water_yield.py:303 msgid "Annual maintenance and operations cost of running the hydropower station. Must be in the same currency used in the 'kw_price' column." msgstr "" -#: src/natcap/invest/annual_water_yield.py:223 +#: src/natcap/invest/annual_water_yield.py:311 msgid "Number of years over which to value the hydropower station. This is either the station's expected lifespan or the duration of the land use scenario of interest." msgstr "" -#: src/natcap/invest/annual_water_yield.py:231 +#: src/natcap/invest/annual_water_yield.py:319 msgid "The annual discount rate, applied for each year in the time span." msgstr "" -#: src/natcap/invest/annual_water_yield.py:237 +#: src/natcap/invest/annual_water_yield.py:326 msgid "A table mapping each watershed to the associated valuation parameters for its hydropower station." msgstr "" -#: src/natcap/invest/annual_water_yield.py:240 +#: src/natcap/invest/annual_water_yield.py:329 msgid "hydropower valuation table" msgstr "" -#: src/natcap/invest/carbon.py:38 +#: src/natcap/invest/carbon.py:59 msgid "A map of LULC for the current scenario. All values in this raster must have corresponding entries in the Carbon Pools table." msgstr "" -#: src/natcap/invest/carbon.py:42 +#: src/natcap/invest/carbon.py:63 msgid "current LULC" msgstr "" -#: src/natcap/invest/carbon.py:47 +#: src/natcap/invest/carbon.py:68 msgid "Run sequestration analysis. This requires inputs of LULC maps for both current and future scenarios. Required if REDD scenario analysis or run valuation model is selected." msgstr "" -#: src/natcap/invest/carbon.py:52 +#: src/natcap/invest/carbon.py:73 msgid "calculate sequestration" msgstr "" -#: src/natcap/invest/carbon.py:59 +#: src/natcap/invest/carbon.py:80 msgid "A map of LULC for the future scenario. If run valuation model is selected, this should be the reference, or baseline, future scenario against which to compare the REDD policy scenario. All values in this raster must have corresponding entries in the Carbon Pools table. Required if Calculate Sequestration is selected." msgstr "" -#: src/natcap/invest/carbon.py:67 +#: src/natcap/invest/carbon.py:88 msgid "future LULC" msgstr "" -#: src/natcap/invest/carbon.py:72 +#: src/natcap/invest/carbon.py:93 msgid "Run REDD scenario analysis. This requires three LULC maps: one for the current scenario, one for the future baseline scenario, and one for the future REDD policy scenario." msgstr "" -#: src/natcap/invest/carbon.py:77 +#: src/natcap/invest/carbon.py:98 msgid "REDD scenario analysis" msgstr "" -#: src/natcap/invest/carbon.py:84 +#: src/natcap/invest/carbon.py:105 msgid "A map of LULC for the REDD policy scenario. All values in this raster must have corresponding entries in the Carbon Pools table. Required if REDD Scenario Analysis is selected." msgstr "" -#: src/natcap/invest/carbon.py:89 +#: src/natcap/invest/carbon.py:110 msgid "REDD LULC" msgstr "" -#: src/natcap/invest/carbon.py:98 +#: src/natcap/invest/carbon.py:119 msgid "Carbon density of aboveground biomass." msgstr "" -#: src/natcap/invest/carbon.py:102 +#: src/natcap/invest/carbon.py:123 msgid "Carbon density of belowground biomass." msgstr "" -#: src/natcap/invest/carbon.py:106 +#: src/natcap/invest/carbon.py:127 msgid "Carbon density of soil." msgstr "" -#: src/natcap/invest/carbon.py:110 +#: src/natcap/invest/carbon.py:131 msgid "Carbon density of dead matter." msgstr "" -#: src/natcap/invest/carbon.py:112 +#: src/natcap/invest/carbon.py:134 msgid "A table that maps each LULC code to carbon pool data for that LULC type." msgstr "" -#: src/natcap/invest/carbon.py:115 +#: src/natcap/invest/carbon.py:137 msgid "carbon pools" msgstr "" -#: src/natcap/invest/carbon.py:122 +#: src/natcap/invest/carbon.py:144 msgid "The calendar year of the current scenario depicted in the current LULC map. Required if Run Valuation model is selected." msgstr "" -#: src/natcap/invest/carbon.py:125 +#: src/natcap/invest/carbon.py:147 msgid "current LULC year" msgstr "" -#: src/natcap/invest/carbon.py:132 +#: src/natcap/invest/carbon.py:154 msgid "The calendar year of the future scenario depicted in the future LULC map. Required if Run Valuation model is selected." msgstr "" -#: src/natcap/invest/carbon.py:140 +#: src/natcap/invest/carbon.py:162 msgid "Calculate net present value for the future scenario, and the REDD scenario if provided, and report it in the final HTML document." msgstr "" -#: src/natcap/invest/carbon.py:144 +#: src/natcap/invest/carbon.py:166 msgid "run valuation model" msgstr "" -#: src/natcap/invest/carbon.py:150 +#: src/natcap/invest/carbon.py:172 msgid "The present value of carbon. Required if Run Valuation model is selected." msgstr "" -#: src/natcap/invest/carbon.py:153 +#: src/natcap/invest/carbon.py:175 msgid "price of carbon" msgstr "" -#: src/natcap/invest/carbon.py:158 +#: src/natcap/invest/carbon.py:180 msgid "The annual market discount rate in the price of carbon, which reflects society's preference for immediate benefits over future benefits. Required if Run Valuation model is selected." msgstr "" -#: src/natcap/invest/carbon.py:163 +#: src/natcap/invest/carbon.py:185 msgid "annual market discount rate" msgstr "" -#: src/natcap/invest/carbon.py:168 +#: src/natcap/invest/carbon.py:190 msgid "The relative annual increase of the price of carbon. Required if Run Valuation model is selected." msgstr "" -#: src/natcap/invest/carbon.py:171 +#: src/natcap/invest/carbon.py:193 msgid "annual price change" msgstr "" -#: src/natcap/invest/cli.py:55 +#: src/natcap/invest/cli.py:56 msgid "Available models:" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:33 +#: src/natcap/invest/coastal_vulnerability.py:36 msgid "Must be a polyline vector" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:34 +#: src/natcap/invest/coastal_vulnerability.py:37 msgid "Must be a point or multipoint geometry." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:60 -msgid "Map of the region over which to run the model." -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:66 -msgid "Interval at which to space shore points along the coastline." -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:68 -msgid "model resolution" -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:74 -msgid "Map of all landmasses in and around the region of interest. It is not recommended to clip this landmass to the AOI polygon because some functions in the model require searching for landmasses around shore points up to the distance defined in Maximum Fetch Distance, which likely extends beyond the AOI polygon." -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:81 -msgid "landmasses" -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:88 +#: src/natcap/invest/coastal_vulnerability.py:93 #, python-format msgid "Proportion of the highest 10% of wind speeds in the record of interest that blow in the direction of each sector." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:95 +#: src/natcap/invest/coastal_vulnerability.py:100 #, python-format msgid "Average of the highest 10% of wind speeds that blow in the direction of each sector." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:100 +#: src/natcap/invest/coastal_vulnerability.py:105 #, python-format msgid "Proportion of the highest 10% of wave power values on record that are in each sector." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:106 +#: src/natcap/invest/coastal_vulnerability.py:111 #, python-format msgid "Average of the highest 10% of wave power values on record in the direction of each sector." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:111 +#: src/natcap/invest/coastal_vulnerability.py:116 #, python-format msgid "Average of the highest 10% of wind speeds that are centered on each main sector direction X." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:116 +#: src/natcap/invest/coastal_vulnerability.py:145 +msgid "Map of the region over which to run the model." +msgstr "" + +#: src/natcap/invest/coastal_vulnerability.py:151 +msgid "Interval at which to space shore points along the coastline." +msgstr "" + +#: src/natcap/invest/coastal_vulnerability.py:153 +msgid "model resolution" +msgstr "" + +#: src/natcap/invest/coastal_vulnerability.py:159 +msgid "Map of all landmasses in and around the region of interest. It is not recommended to clip this landmass to the AOI polygon because some functions in the model require searching for landmasses around shore points up to the distance defined in Maximum Fetch Distance, which likely extends beyond the AOI polygon." +msgstr "" + +#: src/natcap/invest/coastal_vulnerability.py:166 +msgid "landmasses" +msgstr "" + +#: src/natcap/invest/coastal_vulnerability.py:172 msgid "Map of gridded wind and wave data that represent storm conditions. This global dataset is provided with the InVEST sample data. There are 80 required columns; each of the 5 types is repeated for each sixteenth sector of the 360° compass: [0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For example: REI_PCT0, V10PCT_90." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:124 +#: src/natcap/invest/coastal_vulnerability.py:180 msgid "WaveWatchIII" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:130 +#: src/natcap/invest/coastal_vulnerability.py:186 msgid "Maximum distance in meters to extend rays from shore points. Points with rays equal to this distance accumulate ocean- driven wave exposure along those rays and local-wind-driven wave exposure along the shorter rays." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:135 +#: src/natcap/invest/coastal_vulnerability.py:191 msgid "maximum fetch distance" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:143 +#: src/natcap/invest/coastal_vulnerability.py:199 msgid "Map of bathymetry (ocean depth). Bathymetry values should be negative, and any positive values will be ignored. This should cover the area extending beyond the AOI to the maximum fetch distance." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:149 +#: src/natcap/invest/coastal_vulnerability.py:205 msgid "Bathymetry" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:155 +#: src/natcap/invest/coastal_vulnerability.py:211 msgid "Map of the edges of the continental shelf or other locally relevant bathymetry contour." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:158 +#: src/natcap/invest/coastal_vulnerability.py:214 msgid "continental shelf contour" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:166 +#: src/natcap/invest/coastal_vulnerability.py:222 msgid "Map of elevation above sea level on land. This should cover the area extending beyond the AOI by at least the elevation averaging radius. Elevation may be measured in any unit." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:175 +#: src/natcap/invest/coastal_vulnerability.py:231 msgid "A radius around each shore point within which to average the elevation values in the DEM raster." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:178 +#: src/natcap/invest/coastal_vulnerability.py:234 msgid "elevation averaging radius" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:185 +#: src/natcap/invest/coastal_vulnerability.py:241 msgid "Unique name for the habitat. No spaces allowed." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:191 +#: src/natcap/invest/coastal_vulnerability.py:247 msgid "Map of area(s) where the habitat is present. If raster, presence of the habitat can be represented by any value and absence of the habitat can be represented by 0 and nodata values." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:199 -msgid "very high protection" -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:200 -msgid "high protection" -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:201 -msgid "moderate protection" -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:202 -msgid "low protection" -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:203 -msgid "very low protection" -msgstr "" - -#: src/natcap/invest/coastal_vulnerability.py:205 -msgid "Relative amount of coastline protection this habitat provides." +#: src/natcap/invest/coastal_vulnerability.py:254 +msgid "Relative amount of coastline protection this habitat provides, from 1 (very high protection) to 5 (very low protection." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:213 +#: src/natcap/invest/coastal_vulnerability.py:263 msgid "The distance beyond which this habitat will provide no protection to the coastline." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:218 +#: src/natcap/invest/coastal_vulnerability.py:269 msgid "Table that specifies spatial habitat data and parameters." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:220 +#: src/natcap/invest/coastal_vulnerability.py:271 msgid "habitats table" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:228 +#: src/natcap/invest/coastal_vulnerability.py:279 +#: src/natcap/invest/coastal_vulnerability.py:416 msgid "very low exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:229 +#: src/natcap/invest/coastal_vulnerability.py:280 +#: src/natcap/invest/coastal_vulnerability.py:417 msgid "low exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:230 +#: src/natcap/invest/coastal_vulnerability.py:281 +#: src/natcap/invest/coastal_vulnerability.py:418 msgid "moderate exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:231 +#: src/natcap/invest/coastal_vulnerability.py:282 +#: src/natcap/invest/coastal_vulnerability.py:419 msgid "high exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:232 +#: src/natcap/invest/coastal_vulnerability.py:283 +#: src/natcap/invest/coastal_vulnerability.py:420 msgid "very high exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:234 +#: src/natcap/invest/coastal_vulnerability.py:285 +#: src/natcap/invest/coastal_vulnerability.py:422 msgid "Relative exposure of the segment of coastline." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:239 +#: src/natcap/invest/coastal_vulnerability.py:290 msgid "Map of relative exposure of each segment of coastline." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:240 +#: src/natcap/invest/coastal_vulnerability.py:291 msgid "geomorphology" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:245 +#: src/natcap/invest/coastal_vulnerability.py:296 msgid "1: very low exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:246 +#: src/natcap/invest/coastal_vulnerability.py:297 msgid "2: low exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:247 +#: src/natcap/invest/coastal_vulnerability.py:298 msgid "3: moderate exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:248 +#: src/natcap/invest/coastal_vulnerability.py:299 msgid "4: high exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:249 +#: src/natcap/invest/coastal_vulnerability.py:300 msgid "5: very high exposure" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:252 +#: src/natcap/invest/coastal_vulnerability.py:303 msgid "Exposure rank to assign to any shore points that are not near to any segment in the geomorphology vector. Required if a Geomorphology vector is provided." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:256 +#: src/natcap/invest/coastal_vulnerability.py:307 msgid "geomorphology fill value" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:264 +#: src/natcap/invest/coastal_vulnerability.py:315 msgid "Map of total human population on each pixel." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:265 +#: src/natcap/invest/coastal_vulnerability.py:316 msgid "human population" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:272 +#: src/natcap/invest/coastal_vulnerability.py:323 msgid "The radius around each shore point within which to compute the average population density. Required if a Human Population map is provided." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:276 +#: src/natcap/invest/coastal_vulnerability.py:327 msgid "population search radius" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:282 +#: src/natcap/invest/coastal_vulnerability.py:333 msgid "Sea level rise rate or amount. This field name must be chosen as the Sea Level Rise Field." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:291 +#: src/natcap/invest/coastal_vulnerability.py:342 msgid "Map of sea level rise rates or amounts. May be any sea level rise metric of interest, such as rate, or net rise/fall." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:294 +#: src/natcap/invest/coastal_vulnerability.py:345 msgid "sea level rise" msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:300 +#: src/natcap/invest/coastal_vulnerability.py:351 msgid "Name of the field in the sea level rise vector which contains the sea level rise metric of interest. Required if a Sea Level Rise vector is provided." msgstr "" -#: src/natcap/invest/coastal_vulnerability.py:304 +#: src/natcap/invest/coastal_vulnerability.py:355 msgid "sea level rise field" msgstr "" -#: src/natcap/invest/crop_production_percentile.py:96 +#: src/natcap/invest/crop_production_percentile.py:135 msgid "A table that maps each LULC code from the LULC map to one of the 175 canonical crop names representing the crop grown in that LULC class." msgstr "" -#: src/natcap/invest/crop_production_percentile.py:100 +#: src/natcap/invest/crop_production_percentile.py:139 msgid "LULC to Crop Table" msgstr "" -#: src/natcap/invest/crop_production_percentile.py:112 +#: src/natcap/invest/crop_production_percentile.py:151 msgid "Table mapping each climate bin to yield percentiles for each crop." msgstr "" -#: src/natcap/invest/crop_production_percentile.py:142 +#: src/natcap/invest/crop_production_percentile.py:182 +#: src/natcap/invest/crop_production_regression.py:169 msgid "Maps of climate bins for each crop." msgstr "" -#: src/natcap/invest/crop_production_percentile.py:152 +#: src/natcap/invest/crop_production_percentile.py:192 +#: src/natcap/invest/crop_production_regression.py:179 msgid "Maps of actual observed yield for each crop." msgstr "" -#: src/natcap/invest/crop_production_percentile.py:207 +#: src/natcap/invest/crop_production_percentile.py:221 msgid "Path to the InVEST Crop Production Data directory." msgstr "" -#: src/natcap/invest/crop_production_percentile.py:208 +#: src/natcap/invest/crop_production_percentile.py:222 msgid "model data directory" msgstr "" -#: src/natcap/invest/crop_production_regression.py:23 +#: src/natcap/invest/crop_production_regression.py:22 msgid "barley" msgstr "" -#: src/natcap/invest/crop_production_regression.py:24 +#: src/natcap/invest/crop_production_regression.py:23 msgid "maize" msgstr "" -#: src/natcap/invest/crop_production_regression.py:25 +#: src/natcap/invest/crop_production_regression.py:24 msgid "oil palm" msgstr "" -#: src/natcap/invest/crop_production_regression.py:26 +#: src/natcap/invest/crop_production_regression.py:25 msgid "potato" msgstr "" -#: src/natcap/invest/crop_production_regression.py:27 +#: src/natcap/invest/crop_production_regression.py:26 msgid "rice" msgstr "" -#: src/natcap/invest/crop_production_regression.py:28 +#: src/natcap/invest/crop_production_regression.py:27 msgid "soybean" msgstr "" -#: src/natcap/invest/crop_production_regression.py:29 +#: src/natcap/invest/crop_production_regression.py:28 msgid "sugar beet" msgstr "" -#: src/natcap/invest/crop_production_regression.py:30 +#: src/natcap/invest/crop_production_regression.py:29 msgid "sugarcane" msgstr "" -#: src/natcap/invest/crop_production_regression.py:31 +#: src/natcap/invest/crop_production_regression.py:30 msgid "wheat" msgstr "" -#: src/natcap/invest/crop_production_regression.py:61 +#: src/natcap/invest/crop_production_regression.py:96 msgid "A table that maps each LULC code from the LULC map to one of the 10 canonical crop names representing the crop grown in that LULC class." msgstr "" -#: src/natcap/invest/crop_production_regression.py:65 +#: src/natcap/invest/crop_production_regression.py:100 msgid "LULC to crop table" msgstr "" -#: src/natcap/invest/crop_production_regression.py:73 +#: src/natcap/invest/crop_production_regression.py:109 msgid "One of the supported crop types." msgstr "" -#: src/natcap/invest/crop_production_regression.py:81 +#: src/natcap/invest/crop_production_regression.py:117 msgid "A table that maps crops to fertilizer application rates." msgstr "" -#: src/natcap/invest/crop_production_regression.py:83 +#: src/natcap/invest/crop_production_regression.py:119 msgid "fertilization rate table" msgstr "" -#: src/natcap/invest/crop_production_regression.py:156 +#: src/natcap/invest/crop_production_regression.py:191 msgid "The Crop Production datasets provided with the model." msgstr "" -#: src/natcap/invest/crop_production_regression.py:157 +#: src/natcap/invest/crop_production_regression.py:192 msgid "model data" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:50 +#: src/natcap/invest/forest_carbon_edge_effect.py:51 msgid "Number of closest regression models that are used when calculating the total biomass. Each local model is linearly weighted by distance such that the pixel's biomass is a function of each of these points with the closest point having the largest effect. Must be an integer greater than 0. Required if Compute Forest Edge Effects is selected." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:58 +#: src/natcap/invest/forest_carbon_edge_effect.py:59 msgid "number of points to average" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:71 +#: src/natcap/invest/forest_carbon_edge_effect.py:73 msgid "Enter 1 if the LULC class is tropical forest, 0 if it is not tropical forest." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:77 +#: src/natcap/invest/forest_carbon_edge_effect.py:79 msgid "Carbon density value for the aboveground carbon pool." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:85 +#: src/natcap/invest/forest_carbon_edge_effect.py:87 msgid "Carbon density value for the belowground carbon pool. Required if calculating all pools." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:93 +#: src/natcap/invest/forest_carbon_edge_effect.py:95 msgid "Carbon density value for the soil carbon pool. Required if calculating all pools." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:101 +#: src/natcap/invest/forest_carbon_edge_effect.py:103 msgid "Carbon density value for the dead matter carbon pool. Required if calculating all pools." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:106 +#: src/natcap/invest/forest_carbon_edge_effect.py:108 msgid "A table mapping each LULC code from the LULC map to biophysical data for that LULC class." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:122 +#: src/natcap/invest/forest_carbon_edge_effect.py:124 msgid "all" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:123 +#: src/natcap/invest/forest_carbon_edge_effect.py:125 msgid "Use all pools (aboveground, belowground, soil, and dead matter) in the carbon pool calculation." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:127 +#: src/natcap/invest/forest_carbon_edge_effect.py:129 msgid "aboveground only" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:128 +#: src/natcap/invest/forest_carbon_edge_effect.py:130 msgid "Only use the aboveground pool in the carbon pool calculation." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:132 +#: src/natcap/invest/forest_carbon_edge_effect.py:134 msgid "Which carbon pools to consider." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:133 +#: src/natcap/invest/forest_carbon_edge_effect.py:135 msgid "carbon pools to calculate" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:137 +#: src/natcap/invest/forest_carbon_edge_effect.py:139 msgid "Account for forest edge effects on aboveground carbon." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:138 +#: src/natcap/invest/forest_carbon_edge_effect.py:140 msgid "compute forest edge effects" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:146 +#: src/natcap/invest/forest_carbon_edge_effect.py:148 msgid "asymptotic" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:147 +#: src/natcap/invest/forest_carbon_edge_effect.py:149 msgid "logarithmic" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:148 +#: src/natcap/invest/forest_carbon_edge_effect.py:150 msgid "linear" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:150 +#: src/natcap/invest/forest_carbon_edge_effect.py:152 msgid "Optimal regression model for the area." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:155 +#: src/natcap/invest/forest_carbon_edge_effect.py:157 msgid "θ₁ parameter for the regression equation." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:159 +#: src/natcap/invest/forest_carbon_edge_effect.py:161 msgid "θ₂ parameter for the regression equation." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:163 +#: src/natcap/invest/forest_carbon_edge_effect.py:165 msgid "θ₃ parameter for the regression equation. Used only for the asymptotic model." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:169 +#: src/natcap/invest/forest_carbon_edge_effect.py:171 msgid "Map storing the optimal regression model for each tropical subregion and the corresponding theta parameters for that regression equation. Default data is provided. Required if Compute Forest Edge Effects is selected." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:174 +#: src/natcap/invest/forest_carbon_edge_effect.py:176 msgid "global regression models" msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:179 +#: src/natcap/invest/forest_carbon_edge_effect.py:181 msgid "Proportion of forest edge biomass that is elemental carbon. Required if Compute Forest Edge Effects is selected." msgstr "" -#: src/natcap/invest/forest_carbon_edge_effect.py:182 +#: src/natcap/invest/forest_carbon_edge_effect.py:184 msgid "forest edge biomass to carbon conversion factor" msgstr "" -#: src/natcap/invest/habitat_quality.py:22 +#: src/natcap/invest/habitat_quality.py:21 msgid "Threats {threats} does not match any column in the sensitivity table. Sensitivity columns: {column_names}" msgstr "" -#: src/natcap/invest/habitat_quality.py:25 -msgid "The column '{column_name}' was not found in the Threat Data table for the corresponding input LULC scenario." -msgstr "" - -#: src/natcap/invest/habitat_quality.py:28 +#: src/natcap/invest/habitat_quality.py:24 msgid "A threat raster for threats: {threat_list} was not found or it could not be opened by GDAL." msgstr "" -#: src/natcap/invest/habitat_quality.py:31 +#: src/natcap/invest/habitat_quality.py:27 msgid "Threat paths must be unique. Duplicates: " msgstr "" -#: src/natcap/invest/habitat_quality.py:50 +#: src/natcap/invest/habitat_quality.py:46 msgid "Map of LULC at present. All values in this raster must have corresponding entries in the Sensitivity table." msgstr "" -#: src/natcap/invest/habitat_quality.py:53 +#: src/natcap/invest/habitat_quality.py:49 msgid "current land cover" msgstr "" -#: src/natcap/invest/habitat_quality.py:59 +#: src/natcap/invest/habitat_quality.py:55 msgid "Map of LULC in a future scenario. All values in this raster must have corresponding entries in the Sensitivity Table. Must use the same classification scheme and codes as in the Current LULC map." msgstr "" -#: src/natcap/invest/habitat_quality.py:64 +#: src/natcap/invest/habitat_quality.py:60 msgid "future land cover" msgstr "" -#: src/natcap/invest/habitat_quality.py:70 +#: src/natcap/invest/habitat_quality.py:66 msgid "Map of LULC in a baseline scenario, when intensive landscape management was relatively rare. All values in this raster must have corresponding entries in the Sensitivity table. Must use the same classification scheme and codes as in the Current LULC map." msgstr "" -#: src/natcap/invest/habitat_quality.py:76 +#: src/natcap/invest/habitat_quality.py:72 msgid "baseline land cover" msgstr "" -#: src/natcap/invest/habitat_quality.py:83 +#: src/natcap/invest/habitat_quality.py:80 msgid "Name of the threat. Each threat name must have a corresponding column in the Sensitivity table." msgstr "" -#: src/natcap/invest/habitat_quality.py:89 +#: src/natcap/invest/habitat_quality.py:86 msgid "The maximum distance over which each threat affects habitat quality. The impact of each degradation source will decline to zero at this maximum distance. This value must be greater than or equal to the pixel size of your LULC raster(s)." msgstr "" -#: src/natcap/invest/habitat_quality.py:98 +#: src/natcap/invest/habitat_quality.py:95 msgid "The impact of each threat on habitat quality, relative to other threats." msgstr "" -#: src/natcap/invest/habitat_quality.py:106 +#: src/natcap/invest/habitat_quality.py:103 msgid "Effects of the threat decay linearly with distance from the threat." msgstr "" -#: src/natcap/invest/habitat_quality.py:110 +#: src/natcap/invest/habitat_quality.py:107 msgid "Effects of the threat decay exponentially with distance from the threat." msgstr "" -#: src/natcap/invest/habitat_quality.py:114 +#: src/natcap/invest/habitat_quality.py:111 msgid "The type of decay over space for each threat." msgstr "" -#: src/natcap/invest/habitat_quality.py:119 -msgid "Map of the threat's distribution in the current scenario. Each pixel value is the relative intensity of the threat at that location. " +#: src/natcap/invest/habitat_quality.py:116 +msgid "Path to a raster of the threat's distribution in the current scenario. Each pixel value in this raster is the relative intensity of the threat at that location, with values between 0 and 1." msgstr "" -#: src/natcap/invest/habitat_quality.py:128 -msgid "Map of the threat's distribution in the future scenario. Each pixel value is the relative intensity of the threat at that location. Required if Future LULC is provided." +#: src/natcap/invest/habitat_quality.py:127 +msgid "Path to a raster of the threat's distribution in a future scenario. Each pixel value in this raster is the relative intensity of the threat at that location, with values between 0 and 1." msgstr "" #: src/natcap/invest/habitat_quality.py:138 -msgid "Map of the threat's distribution in the baseline scenario. Each pixel value is the relative intensity of the threat at that location. Required if Baseline LULC is provided." +msgid "Path to a raster of the threat's distribution in the baseline scenario. Each pixel value in this raster is the relative intensity of the threat at that location, with values between 0 and 1. Required if Baseline LULC is provided." msgstr "" -#: src/natcap/invest/habitat_quality.py:145 +#: src/natcap/invest/habitat_quality.py:146 msgid "Table mapping each threat of interest to its properties and distribution maps. Paths are relative to the threats table path." msgstr "" -#: src/natcap/invest/habitat_quality.py:149 +#: src/natcap/invest/habitat_quality.py:150 msgid "threats table" msgstr "" -#: src/natcap/invest/habitat_quality.py:157 +#: src/natcap/invest/habitat_quality.py:158 msgid "The region's relative accessibility to threats, where 0 represents completely inaccessible and 1 represents completely accessible." msgstr "" -#: src/natcap/invest/habitat_quality.py:165 +#: src/natcap/invest/habitat_quality.py:166 msgid "Map of the relative protection that legal, institutional, social, and physical barriers provide against threats. Any cells not covered by a polygon will be set to 1." msgstr "" -#: src/natcap/invest/habitat_quality.py:169 +#: src/natcap/invest/habitat_quality.py:170 msgid "accessibility to threats" msgstr "" -#: src/natcap/invest/habitat_quality.py:177 +#: src/natcap/invest/habitat_quality.py:183 msgid "Suitability of this LULC class as habitat, where 0 is not suitable and 1 is completely suitable." msgstr "" -#: src/natcap/invest/habitat_quality.py:183 +#: src/natcap/invest/habitat_quality.py:189 msgid "The relative sensitivity of each LULC class to each type of threat, where 1 represents high sensitivity and 0 represents that it is unaffected. There must be one threat column for each threat name in the 'threats' column of the Threats Table." msgstr "" -#: src/natcap/invest/habitat_quality.py:191 +#: src/natcap/invest/habitat_quality.py:197 msgid "Table mapping each LULC class to data about the species' habitat preference and threat sensitivity in areas with that LULC." msgstr "" -#: src/natcap/invest/habitat_quality.py:195 +#: src/natcap/invest/habitat_quality.py:201 msgid "sensitivity table" msgstr "" -#: src/natcap/invest/habitat_quality.py:201 +#: src/natcap/invest/habitat_quality.py:207 msgid "Half-saturation constant used in the degradation equation." msgstr "" -#: src/natcap/invest/habitat_quality.py:203 +#: src/natcap/invest/habitat_quality.py:209 msgid "half-saturation constant" msgstr "" -#: src/natcap/invest/hra.py:66 +#: src/natcap/invest/hra.py:61 msgid "habitat stressor table" msgstr "" -#: src/natcap/invest/hra.py:67 +#: src/natcap/invest/hra.py:62 msgid "A table describing each habitat and stressor." msgstr "" -#: src/natcap/invest/hra.py:72 +#: src/natcap/invest/hra.py:68 msgid "A unique name for each habitat or stressor. These names must match the habitat and stressor names in the Criteria Scores Table." msgstr "" -#: src/natcap/invest/hra.py:81 +#: src/natcap/invest/hra.py:77 msgid "Pixel values are 1, indicating presence of the habitat/stressor, or 0 indicating absence. Any values besides 0 or 1 will be treated as 0." msgstr "" -#: src/natcap/invest/hra.py:88 +#: src/natcap/invest/hra.py:84 msgid "Map of where the habitat or stressor exists. For rasters, a pixel value of 1 indicates presence of the habitat or stressor. 0 (or any other value) indicates absence of the habitat or stressor. For vectors, a polygon indicates an area where the habitat or stressor is present." msgstr "" -#: src/natcap/invest/hra.py:99 +#: src/natcap/invest/hra.py:95 msgid "habitat" msgstr "" -#: src/natcap/invest/hra.py:100 +#: src/natcap/invest/hra.py:96 msgid "stressor" msgstr "" -#: src/natcap/invest/hra.py:102 +#: src/natcap/invest/hra.py:98 msgid "Whether this row is for a habitat or a stressor." msgstr "" -#: src/natcap/invest/hra.py:108 +#: src/natcap/invest/hra.py:104 msgid "The desired buffer distance used to expand a given stressor’s influence or footprint. This should be left blank for habitats, but must be filled in for stressors. Enter 0 if no buffering is desired for a given stressor. The model will round down this buffer distance to the nearest cell unit. e.g., a buffer distance of 600m will buffer a stressor’s footprint by two grid cells if the resolution of analysis is 250m." msgstr "" -#: src/natcap/invest/hra.py:123 +#: src/natcap/invest/hra.py:118 msgid "criteria scores table" msgstr "" -#: src/natcap/invest/hra.py:124 +#: src/natcap/invest/hra.py:119 msgid "A table of criteria scores for all habitats and stressors." msgstr "" -#: src/natcap/invest/hra.py:130 +#: src/natcap/invest/hra.py:124 msgid "resolution of analysis" msgstr "" -#: src/natcap/invest/hra.py:131 +#: src/natcap/invest/hra.py:125 msgid "The resolution at which to run the analysis. The model outputs will have this resolution." msgstr "" -#: src/natcap/invest/hra.py:139 +#: src/natcap/invest/hra.py:133 msgid "maximum criteria score" msgstr "" -#: src/natcap/invest/hra.py:140 +#: src/natcap/invest/hra.py:134 msgid "The highest possible criteria score in the scoring system." msgstr "" -#: src/natcap/invest/hra.py:147 +#: src/natcap/invest/hra.py:141 msgid "risk equation" msgstr "" -#: src/natcap/invest/hra.py:148 +#: src/natcap/invest/hra.py:142 msgid "The equation to use to calculate risk from exposure and consequence." msgstr "" -#: src/natcap/invest/hra.py:153 +#: src/natcap/invest/hra.py:147 msgid "Multiplicative" msgstr "" -#: src/natcap/invest/hra.py:154 +#: src/natcap/invest/hra.py:148 msgid "Euclidean" msgstr "" -#: src/natcap/invest/hra.py:158 +#: src/natcap/invest/hra.py:152 msgid "decay equation" msgstr "" -#: src/natcap/invest/hra.py:159 +#: src/natcap/invest/hra.py:153 msgid "The equation to model effects of stressors in buffer areas." msgstr "" -#: src/natcap/invest/hra.py:164 +#: src/natcap/invest/hra.py:158 msgid "None" msgstr "" -#: src/natcap/invest/hra.py:165 +#: src/natcap/invest/hra.py:159 msgid "No decay. Stressor has full effect in the buffer area." msgstr "" -#: src/natcap/invest/hra.py:169 +#: src/natcap/invest/hra.py:163 msgid "Linear" msgstr "" -#: src/natcap/invest/hra.py:170 +#: src/natcap/invest/hra.py:164 msgid "Stressor effects in the buffer area decay linearly with distance from the stressor." msgstr "" -#: src/natcap/invest/hra.py:174 +#: src/natcap/invest/hra.py:168 msgid "Exponential" msgstr "" -#: src/natcap/invest/hra.py:175 +#: src/natcap/invest/hra.py:169 msgid "Stressor effects in the buffer area decay exponentially with distance from the stressor." msgstr "" -#: src/natcap/invest/hra.py:188 +#: src/natcap/invest/hra.py:182 msgid "Uniquely identifies each feature. Required if the vector contains more than one feature." msgstr "" -#: src/natcap/invest/hra.py:193 +#: src/natcap/invest/hra.py:187 msgid "A GDAL-supported vector file containing features representing one or more planning regions or subregions." msgstr "" -#: src/natcap/invest/hra.py:198 +#: src/natcap/invest/hra.py:192 msgid "Number of Overlapping Stressors" msgstr "" -#: src/natcap/invest/hra.py:201 +#: src/natcap/invest/hra.py:195 msgid "The number of overlapping stressors to consider as 'maximum' when reclassifying risk scores into high/medium/low. Affects the breaks between risk classifications." msgstr "" -#: src/natcap/invest/hra.py:210 +#: src/natcap/invest/hra.py:204 msgid "Generate GeoJSONs" msgstr "" -#: src/natcap/invest/hra.py:211 +#: src/natcap/invest/hra.py:205 msgid "Generate GeoJSON outputs for web visualization." msgstr "" @@ -1052,230 +1038,303 @@ msgstr "" msgid "Urban Cooling" msgstr "" +#: src/natcap/invest/model_metadata.py:162 +msgid "Urban Nature Access" +msgstr "" + #: src/natcap/invest/pollination.py:37 msgid "Map of LULC codes. All values in this raster must have corresponding entries in the Biophysical Table." msgstr "" -#: src/natcap/invest/pollination.py:46 +#: src/natcap/invest/pollination.py:47 msgid "Unique name or identifier for each pollinator species or guild of interest." msgstr "" -#: src/natcap/invest/pollination.py:52 +#: src/natcap/invest/pollination.py:53 msgid "Utilization of the substrate by this species, where 1 indicates the nesting substrate is fully utilized and 0 indicates it is not utilized at all. Replace [SUBSTRATE] with substrate names matching those in the Biophysical Table, so that there is a column for each substrate." msgstr "" -#: src/natcap/invest/pollination.py:62 +#: src/natcap/invest/pollination.py:63 msgid "Pollinator activity for this species/guild in each season. 1 indicates maximum activity for the species/guild, and 0 indicates no activity. Replace [SEASON] with season names matching those in the biophysical table, so that there is a column for each season." msgstr "" -#: src/natcap/invest/pollination.py:73 +#: src/natcap/invest/pollination.py:74 msgid "Average distance that this species or guild travels to forage on flowers." msgstr "" -#: src/natcap/invest/pollination.py:79 +#: src/natcap/invest/pollination.py:80 msgid "The proportion of total pollinator abundance that consists of this species/guild." msgstr "" -#: src/natcap/invest/pollination.py:84 +#: src/natcap/invest/pollination.py:85 msgid "A table mapping each pollinator species or guild of interest to its pollination-related parameters." msgstr "" -#: src/natcap/invest/pollination.py:87 +#: src/natcap/invest/pollination.py:88 msgid "Guild Table" msgstr "" -#: src/natcap/invest/pollination.py:95 +#: src/natcap/invest/pollination.py:97 msgid "Index of availability of the given substrate in this LULC class. Replace [SUBSTRATE] with substrate names matching those in the Guild Table, so that there is a column for each substrate." msgstr "" -#: src/natcap/invest/pollination.py:102 +#: src/natcap/invest/pollination.py:104 msgid "Abundance of flowers during the given season in this LULC class. This is the proportion of land area covered by flowers, multiplied by the proportion of the season for which there is that coverage. Replace [SEASON] with season names matching those in the Guild Table, so that there is a column for each season." msgstr "" -#: src/natcap/invest/pollination.py:111 +#: src/natcap/invest/pollination.py:113 msgid "A table mapping each LULC class to nesting availability and floral abundance data for each substrate and season in that LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "" -#: src/natcap/invest/pollination.py:123 +#: src/natcap/invest/pollination.py:125 msgid "Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', etc." msgstr "" -#: src/natcap/invest/pollination.py:128 +#: src/natcap/invest/pollination.py:130 msgid "The half saturation coefficient for the crop grown in this area. This is the wild pollinator abundance (i.e. the proportion of all pollinators that are wild) needed to reach half of the total potential pollinator-dependent yield." msgstr "" -#: src/natcap/invest/pollination.py:136 +#: src/natcap/invest/pollination.py:138 msgid "The season in which the crop is pollinated. Season names must match those in the Guild Table and Biophysical Table." msgstr "" -#: src/natcap/invest/pollination.py:142 +#: src/natcap/invest/pollination.py:144 msgid "The floral resources available at this farm for the given season. Replace [SEASON] with season names matching those in the Guild Table and Biophysical Table, so that there is one field for each season." msgstr "" -#: src/natcap/invest/pollination.py:150 +#: src/natcap/invest/pollination.py:152 msgid "The nesting suitability for the given substrate at this farm. given substrate. Replace [SUBSTRATE] with substrate names matching those in the Guild Table and Biophysical Table, so that there is one field for each substrate." msgstr "" -#: src/natcap/invest/pollination.py:158 +#: src/natcap/invest/pollination.py:160 msgid "The proportion of crop dependent on pollinators." msgstr "" -#: src/natcap/invest/pollination.py:163 +#: src/natcap/invest/pollination.py:165 msgid "The proportion of pollination required on the farm that is provided by managed pollinators." msgstr "" -#: src/natcap/invest/pollination.py:169 +#: src/natcap/invest/pollination.py:171 msgid "Map of farm sites to be analyzed, with pollination data specific to each farm." msgstr "" -#: src/natcap/invest/pollination.py:172 +#: src/natcap/invest/pollination.py:174 msgid "farms map" msgstr "" -#: src/natcap/invest/routedem.py:20 +#: src/natcap/invest/pollination.py:180 +msgid "A copy of the input farm polygon vector file with additional fields" +msgstr "" + +#: src/natcap/invest/pollination.py:212 +msgid "Total pollinator abundance across all species per season, clipped to the geometry of the farm vector’s polygons." +msgstr "" + +#: src/natcap/invest/pollination.py:218 +msgid "Abundance of pollinator SPECIES in season SEASON." +msgstr "" + +#: src/natcap/invest/pollination.py:222 +msgid "Index of pollinator SPECIES that could be on a pixel given its arbitrary abundance factor from the table, multiplied by the habitat suitability for that species at that pixel, multiplied by the available floral resources that a pollinator could fly to from that pixel." +msgstr "" + +#: src/natcap/invest/pollination.py:232 +msgid "Total pollinator abundance across all species per season." +msgstr "" + +#: src/natcap/invest/pollination.py:238 +msgid "Total pollinator yield index for pixels that overlap farms, including wild and managed pollinators." +msgstr "" + +#: src/natcap/invest/pollination.py:245 +msgid "Pollinator yield index for pixels that overlap farms, for wild pollinators only." +msgstr "" + +#: src/natcap/invest/routedem.py:18 msgid "Must be between 1 and {maximum}" msgstr "" -#: src/natcap/invest/routedem.py:36 +#: src/natcap/invest/routedem.py:34 msgid "Index of the raster band to use, for multi-band rasters." msgstr "" -#: src/natcap/invest/routedem.py:38 +#: src/natcap/invest/routedem.py:36 msgid "band index" msgstr "" -#: src/natcap/invest/routedem.py:45 +#: src/natcap/invest/routedem.py:43 msgid "All water on a pixel flows into the most downhill of its 8 surrounding pixels" msgstr "" -#: src/natcap/invest/routedem.py:50 +#: src/natcap/invest/routedem.py:48 msgid "Flow off a pixel is modeled fractionally so that water is split among multiple downslope pixels" msgstr "" -#: src/natcap/invest/routedem.py:54 +#: src/natcap/invest/routedem.py:52 msgid "The routing algorithm to use." msgstr "" -#: src/natcap/invest/routedem.py:55 +#: src/natcap/invest/routedem.py:53 msgid "routing algorithm" msgstr "" -#: src/natcap/invest/routedem.py:60 +#: src/natcap/invest/routedem.py:58 msgid "Calculate flow direction from the provided DEM." msgstr "" -#: src/natcap/invest/routedem.py:61 +#: src/natcap/invest/routedem.py:59 msgid "calculate flow direction" msgstr "" -#: src/natcap/invest/routedem.py:66 +#: src/natcap/invest/routedem.py:64 msgid "Calculate flow accumulation from the flow direction output." msgstr "" -#: src/natcap/invest/routedem.py:68 +#: src/natcap/invest/routedem.py:66 msgid "calculate flow accumulation" msgstr "" -#: src/natcap/invest/routedem.py:73 +#: src/natcap/invest/routedem.py:71 msgid "Calculate streams from the flow accumulation output. " msgstr "" -#: src/natcap/invest/routedem.py:75 +#: src/natcap/invest/routedem.py:73 msgid "calculate streams" msgstr "" -#: src/natcap/invest/routedem.py:82 +#: src/natcap/invest/routedem.py:80 msgid "Required if Calculate Streams is selected." msgstr "" -#: src/natcap/invest/routedem.py:87 +#: src/natcap/invest/routedem.py:85 msgid "Calculate flow distance from each pixel to a stream as defined in the Calculate Streams output." msgstr "" -#: src/natcap/invest/routedem.py:90 +#: src/natcap/invest/routedem.py:88 msgid "calculate distance to stream" msgstr "" -#: src/natcap/invest/routedem.py:95 +#: src/natcap/invest/routedem.py:93 msgid "Calculate percent slope from the provided DEM." msgstr "" -#: src/natcap/invest/routedem.py:96 +#: src/natcap/invest/routedem.py:94 msgid "calculate slope" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:29 +#: src/natcap/invest/routedem.py:99 +msgid "Calculate the Strahler Stream order." +msgstr "" + +#: src/natcap/invest/routedem.py:100 +msgid "calculate strahler stream orders (D8 only)" +msgstr "" + +#: src/natcap/invest/routedem.py:105 +msgid "Determine subwatersheds from the stream order." +msgstr "" + +#: src/natcap/invest/routedem.py:106 +msgid "calculate subwatersheds (D8 only)" +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:28 msgid "One or more of \"convert_nearest_to_edge\" or \"convert_farthest_from_edge\" must be selected" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:44 +#: src/natcap/invest/scenario_gen_proximity.py:43 msgid "Base map from which to generate scenarios." msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:45 +#: src/natcap/invest/scenario_gen_proximity.py:44 msgid "base LULC map" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:49 +#: src/natcap/invest/scenario_gen_proximity.py:48 msgid "The LULC code to which habitat will be converted." msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:50 +#: src/natcap/invest/scenario_gen_proximity.py:49 msgid "replacement landcover code" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:56 +#: src/natcap/invest/scenario_gen_proximity.py:55 msgid "Maximum area to be converted to agriculture." msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:57 +#: src/natcap/invest/scenario_gen_proximity.py:56 msgid "maximum area to convert" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:62 +#: src/natcap/invest/scenario_gen_proximity.py:61 msgid "A space-separated list of LULC codes that are used to determine the proximity when referring to 'towards' or 'away' from the base landcover codes" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:66 +#: src/natcap/invest/scenario_gen_proximity.py:65 msgid "focal landcover codes" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:71 +#: src/natcap/invest/scenario_gen_proximity.py:70 msgid "A space-separated list of LULC codes that can be converted to be converted to agriculture." msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:74 +#: src/natcap/invest/scenario_gen_proximity.py:73 msgid "convertible landcover codes" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:80 +#: src/natcap/invest/scenario_gen_proximity.py:79 msgid "The number of steps that the simulation should take to fragment the habitat of interest in the fragmentation scenario. This parameter is used to divide the conversion simulation into equal subareas of the requested max area. During each sub-step the distance transform is recalculated from the base landcover codes. This can affect the final result if the base types are also convertible types." msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:88 +#: src/natcap/invest/scenario_gen_proximity.py:87 msgid "number of conversion steps" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:93 +#: src/natcap/invest/scenario_gen_proximity.py:92 msgid "Area over which to run the conversion. Provide this input if change is only desired in a subregion of the Base LULC map." msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:99 +#: src/natcap/invest/scenario_gen_proximity.py:98 msgid "Convert the 'convertible' landcover codes starting at the furthest pixel from the 'focal' land cover areas and working inwards." msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:103 +#: src/natcap/invest/scenario_gen_proximity.py:102 msgid "convert farthest from edge" msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:107 +#: src/natcap/invest/scenario_gen_proximity.py:106 msgid "Convert the 'convertible' landcover codes starting at the nearest pixels to the 'focal' land cover areas and working outwards." msgstr "" -#: src/natcap/invest/scenario_gen_proximity.py:111 +#: src/natcap/invest/scenario_gen_proximity.py:110 msgid "convert nearest to edge" msgstr "" +#: src/natcap/invest/scenario_gen_proximity.py:115 +msgid "Map of the nearest-to-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:119 +msgid "Map of the farthest-from-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:123 +#: src/natcap/invest/scenario_gen_proximity.py:143 +msgid "Table of land cover classes and the amount of each that was converted for the nearest-to-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:166 +msgid "Copy of the LULC raster masked to the AOI extent." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:171 +msgid "Map of the distance from each pixel to the farthest edge of the focal landcover." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:177 +msgid "Map of the distance from each pixel to the nearest edge of the focal landcover." +msgstr "" + #: src/natcap/invest/spec_utils.py:12 msgid "workspace" msgstr "" @@ -1357,1207 +1416,1577 @@ msgid "threshold flow accumulation" msgstr "" #: src/natcap/invest/spec_utils.py:125 -#: src/natcap/invest/urban_flood_risk_mitigation.py:63 +#: src/natcap/invest/urban_flood_risk_mitigation.py:64 msgid "LULC codes from the LULC raster. Each code must be a unique integer." msgstr "" -#: src/natcap/invest/spec_utils.py:173 -msgid "number of pixels" +#: src/natcap/invest/spec_utils.py:141 +msgid "Map of elevation after any pits are filled" msgstr "" -#: src/natcap/invest/spec_utils.py:174 -msgid "currency units" +#: src/natcap/invest/spec_utils.py:148 +msgid "Map of flow accumulation" +msgstr "" + +#: src/natcap/invest/spec_utils.py:155 +msgid "MFD flow direction. Note: the pixel values should not be interpreted directly. Each 32-bit number consists of 8 4-bit numbers. Each 4-bit number represents the proportion of flow into one of the eight neighboring pixels." msgstr "" -#: src/natcap/invest/spec_utils.py:183 +#: src/natcap/invest/spec_utils.py:164 +msgid "D8 flow direction." +msgstr "" + +#: src/natcap/invest/spec_utils.py:169 +msgid "Percent slope, calculated from the pit-filled DEM. 100 is equivalent to a 45 degree slope." +msgstr "" + +#: src/natcap/invest/spec_utils.py:222 +msgid "number of pixels" +msgstr "" + +#: src/natcap/invest/spec_utils.py:231 msgid "unitless" msgstr "" -#: src/natcap/invest/spec_utils.py:254 +#: src/natcap/invest/spec_utils.py:251 +msgid "currency units" +msgstr "" + +#: src/natcap/invest/spec_utils.py:306 msgid "required" msgstr "" -#: src/natcap/invest/spec_utils.py:256 +#: src/natcap/invest/spec_utils.py:308 msgid "optional" msgstr "" -#: src/natcap/invest/spec_utils.py:259 +#: src/natcap/invest/spec_utils.py:311 msgid "conditionally required" msgstr "" -#: src/natcap/invest/spec_utils.py:289 +#: src/natcap/invest/spec_utils.py:341 msgid "read" msgstr "" -#: src/natcap/invest/spec_utils.py:291 +#: src/natcap/invest/spec_utils.py:343 msgid "write" msgstr "" -#: src/natcap/invest/spec_utils.py:293 +#: src/natcap/invest/spec_utils.py:345 msgid "execute" msgstr "" -#: src/natcap/invest/spec_utils.py:366 +#: src/natcap/invest/spec_utils.py:422 msgid "true/false" msgstr "" -#: src/natcap/invest/spec_utils.py:367 +#: src/natcap/invest/spec_utils.py:423 msgid "CSV" msgstr "" -#: src/natcap/invest/spec_utils.py:368 +#: src/natcap/invest/spec_utils.py:424 msgid "directory" msgstr "" -#: src/natcap/invest/spec_utils.py:369 +#: src/natcap/invest/spec_utils.py:425 msgid "file" msgstr "" -#: src/natcap/invest/spec_utils.py:370 +#: src/natcap/invest/spec_utils.py:426 msgid "text" msgstr "" -#: src/natcap/invest/spec_utils.py:371 +#: src/natcap/invest/spec_utils.py:427 msgid "integer" msgstr "" -#: src/natcap/invest/spec_utils.py:372 +#: src/natcap/invest/spec_utils.py:428 msgid "number" msgstr "" -#: src/natcap/invest/spec_utils.py:373 +#: src/natcap/invest/spec_utils.py:429 msgid "option" msgstr "" -#: src/natcap/invest/spec_utils.py:374 +#: src/natcap/invest/spec_utils.py:430 msgid "percent" msgstr "" -#: src/natcap/invest/spec_utils.py:375 +#: src/natcap/invest/spec_utils.py:431 msgid "raster" msgstr "" -#: src/natcap/invest/spec_utils.py:376 +#: src/natcap/invest/spec_utils.py:432 msgid "ratio" msgstr "" -#: src/natcap/invest/spec_utils.py:377 +#: src/natcap/invest/spec_utils.py:433 msgid "vector" msgstr "" -#: src/natcap/invest/spec_utils.py:448 +#: src/natcap/invest/spec_utils.py:504 msgid "units" msgstr "" -#: src/natcap/invest/spec_utils.py:476 src/natcap/invest/spec_utils.py:480 +#: src/natcap/invest/spec_utils.py:533 src/natcap/invest/spec_utils.py:537 msgid "Options:" msgstr "" -#: src/natcap/invest/spec_utils.py:484 +#: src/natcap/invest/spec_utils.py:541 msgid " Please see the sample data table for details on the format." msgstr "" -#: src/natcap/invest/stormwater.py:54 +#: src/natcap/invest/stormwater.py:56 msgid "Event mean concentration of the pollutant in stormwater. You may include any number of these columns for different pollutants, or none at all." msgstr "" -#: src/natcap/invest/stormwater.py:63 +#: src/natcap/invest/stormwater.py:65 msgid "Stormwater runoff coefficient for soil group" msgstr "" -#: src/natcap/invest/stormwater.py:72 +#: src/natcap/invest/stormwater.py:74 msgid "Stormwater percolation coefficient for soil group" msgstr "" -#: src/natcap/invest/stormwater.py:82 +#: src/natcap/invest/stormwater.py:84 msgid "Enter 1 if the LULC class is a connected impervious surface, 0 if not. This column is only used if the 'adjust retention ratios' option is selected. If 'adjust retention ratios' is selected and this column exists, the adjustment algorithm takes into account the LULC as well as road centerlines. If this column does not exist, only the road centerlines are used." msgstr "" -#: src/natcap/invest/stormwater.py:93 +#: src/natcap/invest/stormwater.py:95 msgid "Table mapping each LULC code found in the LULC raster to biophysical data about that LULC class. If you provide the percolation coefficient column (PE_[X]) for any soil group, you must provide it for all four soil groups." msgstr "" -#: src/natcap/invest/stormwater.py:98 +#: src/natcap/invest/stormwater.py:100 msgid "Biophysical table" msgstr "" -#: src/natcap/invest/stormwater.py:102 +#: src/natcap/invest/stormwater.py:104 msgid "If true, adjust retention ratios. The adjustment algorithm accounts for drainage effects of nearby impervious surfaces which are directly connected to artifical urban drainage channels (typically roads, parking lots, etc.) Connected impervious surfaces are indicated by the is_connected columnin the biophysical table and/or the road centerlines vector." msgstr "" -#: src/natcap/invest/stormwater.py:109 +#: src/natcap/invest/stormwater.py:111 msgid "Adjust retention ratios" msgstr "" -#: src/natcap/invest/stormwater.py:115 +#: src/natcap/invest/stormwater.py:117 msgid "Radius around each pixel to adjust retention ratios. Measured in raster coordinate system units. For the adjustment algorithm, a pixel is 'near' a connected impervious surface if its centerpoint is within this radius of connected-impervious LULC and/or a road centerline." msgstr "" -#: src/natcap/invest/stormwater.py:121 +#: src/natcap/invest/stormwater.py:123 msgid "Retention radius" msgstr "" -#: src/natcap/invest/stormwater.py:128 +#: src/natcap/invest/stormwater.py:130 msgid "Map of road centerlines" msgstr "" -#: src/natcap/invest/stormwater.py:129 +#: src/natcap/invest/stormwater.py:131 msgid "Road centerlines" msgstr "" -#: src/natcap/invest/stormwater.py:134 +#: src/natcap/invest/stormwater.py:136 msgid "Areas over which to aggregate results (typically watersheds or sewersheds). The aggregated data are: average retention ratio and total retention volume; average percolation ratio and total percolation volume if percolation data was provided; total retention value if replacement cost was provided; and total avoided pollutant load for each pollutant provided." msgstr "" -#: src/natcap/invest/stormwater.py:147 +#: src/natcap/invest/stormwater.py:149 msgid "Replacement cost of stormwater retention devices" msgstr "" -#: src/natcap/invest/stormwater.py:148 +#: src/natcap/invest/stormwater.py:150 msgid "Replacement cost" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:48 -msgid "Map of LULC for the area of interest. All values in this raster must have corresponding entries in the Biophysical Table." +#: src/natcap/invest/stormwater.py:155 +msgid "Map of the stormwater retention ratio, derived from the LULC raster and biophysical table RC_x columns." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:66 -msgid "Enter 1 to indicate that the LULC is considered a green area. Enter 0 to indicate that the LULC is not considered a green area." +#: src/natcap/invest/stormwater.py:162 +msgid "Map of the adjusted retention ratio, calculated according to equation (124) from the ‘retention_ratio, ratio_average, near_road’, and ‘near_impervious_lulc’ intermediate outputs." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:73 -msgid "The proportion of area in this LULC class that is covered by tree canopy at least 2 meters high. Required if the 'factors' option is selected for the Cooling Capacity Calculation Method." +#: src/natcap/invest/stormwater.py:169 +msgid "Map of retention volume." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:81 -msgid "The proportion of solar radiation that is directly reflected by this LULC class. Required if the 'factors' option is selected for the Cooling Capacity Calculation Method." +#: src/natcap/invest/stormwater.py:177 +msgid "Map of percolation ratio derived by cross-referencing the LULC and soil group rasters with the biophysical table." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:89 -msgid "The ratio of building floor area to footprint area, with all values in this column normalized between 0 and 1. Required if the 'intensity' option is selected for the Cooling Capacity Calculation Method." +#: src/natcap/invest/stormwater.py:184 +msgid "Map of percolation (potential aquifer recharge) volume." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:96 -msgid "A table mapping each LULC code to biophysical data for that LULC class. All values in the LULC raster must have corresponding entries in this table." +#: src/natcap/invest/stormwater.py:191 +msgid "Map of the stormwater runoff ratio. This is the inverse of ‘retention_ratio.tif’" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:105 -msgid "maximum cooling distance" +#: src/natcap/invest/stormwater.py:197 +msgid "Map of runoff volume." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:106 -msgid "Distance over which green areas larger than 2 hectares have a cooling effect." +#: src/natcap/invest/stormwater.py:205 +msgid "Map of the value of water retained." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:114 -msgid "air blending distance" +#: src/natcap/invest/stormwater.py:213 +msgid "Map of aggregate data. This is identical to the aggregate areas input vector, but each polygon is given additional fields with the aggregate data." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:115 -msgid "Radius over which to average air temperatures to account for air mixing." +#: src/natcap/invest/stormwater.py:221 +msgid "Average retention ratio over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:120 -msgid "reference air temperature" +#: src/natcap/invest/stormwater.py:226 +msgid "Total retention volume over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:123 -msgid "Air temperature in a rural reference area where the urban heat island effect is not observed." +#: src/natcap/invest/stormwater.py:230 +msgid "Average runoff coefficient over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:128 -msgid "UHI effect" +#: src/natcap/invest/stormwater.py:235 +msgid "Total runoff volume over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:131 -msgid "The magnitude of the urban heat island effect, i.e., the difference between the rural reference temperature and the maximum temperature observed in the city." +#: src/natcap/invest/stormwater.py:239 +msgid "Average percolation (recharge) ratio over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:137 -msgid "run energy savings valuation" +#: src/natcap/invest/stormwater.py:244 +msgid "Total volume of potential aquifer recharge over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:139 -msgid "Run the energy savings valuation model." +#: src/natcap/invest/stormwater.py:249 +msgid "Total avoided (retained) amount of pollutant over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:142 -msgid "run work productivity valuation" +#: src/natcap/invest/stormwater.py:254 +msgid "Total amount of pollutant in runoff over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:144 -msgid "Run the work productivity valuation model." +#: src/natcap/invest/stormwater.py:260 +msgid "Total value of the retained volume of water over this polygon" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:147 -msgid "average relative humidity" +#: src/natcap/invest/stormwater.py:270 +msgid "Copy of the soil group raster input, cropped to the intersection of the three raster inputs." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:150 -msgid "The average relative humidity over the time period of interest. Required if Run Work Productivity Valuation is selected." +#: src/natcap/invest/stormwater.py:276 +msgid "Copy of the soil group raster input, aligned to the LULC raster and cropped to the intersection of the three raster inputs." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:156 -msgid "buildings" +#: src/natcap/invest/stormwater.py:283 +msgid "Copy of the precipitation raster input, aligned to the LULC raster and cropped to the intersection of the three raster inputs." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:161 -msgid "Code indicating the building type. These codes must match those in the Energy Consumption Table." +#: src/natcap/invest/stormwater.py:295 +msgid "Copy of the road centerlines vector input, reprojected to the LULC raster projection." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:166 -msgid "A map of built infrastructure footprints. Required if Run Energy Savings Valuation is selected." +#: src/natcap/invest/stormwater.py:303 +msgid "A rasterized version of the reprojected centerlines vector, where 1 means the pixel is a road and 0 means it isn’t." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:171 -msgid "energy consumption table" +#: src/natcap/invest/stormwater.py:310 +msgid "A binary raster derived from the LULC raster and biophysical table is_connected column, where 1 means the pixel has a directly-connected impervious LULC type, and 0 means it does not." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:176 -msgid "Building type codes matching those in the Buildings vector." +#: src/natcap/invest/stormwater.py:318 +msgid "A raster derived from the rasterized centerlines map, where each pixel’s value is its minimum distance to a road pixel (measured centerpoint-to-centerpoint)." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:183 -msgid "Energy consumption by footprint area for this building type." +#: src/natcap/invest/stormwater.py:328 +msgid "A raster derived from the is_connected_lulc map, where each pixel’s value is its minimum distance to a connected impervious LULC pixel (measured centerpoint-to-centerpoint)." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:191 -msgid "The cost of electricity for this building type. If this column is provided, the energy savings outputs will be in the this currency unit rather than kWh." +#: src/natcap/invest/stormwater.py:339 +msgid "A binary raster derived from the road_distance map, where 1 means the pixel is within the retention radius of a road pixel, and 0 means it isn’t." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:199 -msgid "A table of energy consumption data for each building type. Required if Run Energy Savings Valuation is selected." +#: src/natcap/invest/stormwater.py:346 +msgid "A binary raster derived from the connected_lulc_distance map, where 1 means the pixel is within the retention radius of a connected impervious LULC pixel, and 0 means it isn’t." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:204 -msgid "cooling capacity calculation method" +#: src/natcap/invest/stormwater.py:354 +msgid "A binary raster representing the search kernel that is convolved with the retention_ratio raster to calculate the averaged retention ratio within the retention radius of each pixel." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:208 -msgid "factors" +#: src/natcap/invest/stormwater.py:362 +msgid "A raster where each pixel’s value is the average of its neighborhood of pixels in the retention_ratio map, calculated by convolving the search kernel with the retention ratio raster." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:209 -msgid "Use the weighted shade, albedo, and ETI factors as a temperature predictor (for daytime temperatures)." +#: src/natcap/invest/urban_cooling_model.py:49 +msgid "Map of LULC for the area of interest. All values in this raster must have corresponding entries in the Biophysical Table." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:213 -msgid "intensity" +#: src/natcap/invest/urban_cooling_model.py:68 +msgid "Enter 1 to indicate that the LULC is considered a green area. Enter 0 to indicate that the LULC is not considered a green area." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:214 -msgid "Use building intensity as a temperature predictor (for nighttime temperatures)." +#: src/natcap/invest/urban_cooling_model.py:75 +msgid "The proportion of area in this LULC class that is covered by tree canopy at least 2 meters high. Required if the 'factors' option is selected for the Cooling Capacity Calculation Method." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:218 -msgid "The air temperature predictor method to use." +#: src/natcap/invest/urban_cooling_model.py:83 +msgid "The proportion of solar radiation that is directly reflected by this LULC class. Required if the 'factors' option is selected for the Cooling Capacity Calculation Method." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:221 -msgid "shade weight" +#: src/natcap/invest/urban_cooling_model.py:91 +msgid "The ratio of building floor area to footprint area, with all values in this column normalized between 0 and 1. Required if the 'intensity' option is selected for the Cooling Capacity Calculation Method." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:224 -msgid "The relative weight to apply to shade when calculating the cooling capacity index. If not provided, defaults to 0.6." +#: src/natcap/invest/urban_cooling_model.py:98 +msgid "A table mapping each LULC code to biophysical data for that LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:229 -msgid "albedo weight" +#: src/natcap/invest/urban_cooling_model.py:107 +msgid "maximum cooling distance" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:232 -msgid "The relative weight to apply to albedo when calculating the cooling capacity index. If not provided, defaults to 0.2." +#: src/natcap/invest/urban_cooling_model.py:108 +msgid "Distance over which green areas larger than 2 hectares have a cooling effect." msgstr "" -#: src/natcap/invest/urban_cooling_model.py:237 -msgid "evapotranspiration weight" +#: src/natcap/invest/urban_cooling_model.py:116 +msgid "air blending distance" msgstr "" -#: src/natcap/invest/urban_cooling_model.py:240 -msgid "The relative weight to apply to ETI when calculating the cooling capacity index. If not provided, defaults to 0.2." +#: src/natcap/invest/urban_cooling_model.py:117 +msgid "Radius over which to average air temperatures to account for air mixing." msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:44 -msgid "Depth of rainfall for the design storm of interest." +#: src/natcap/invest/urban_cooling_model.py:122 +msgid "reference air temperature" msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:45 -msgid "rainfall depth" +#: src/natcap/invest/urban_cooling_model.py:125 +msgid "Air temperature in a rural reference area where the urban heat island effect is not observed." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:130 +msgid "UHI effect" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:133 +msgid "The magnitude of the urban heat island effect, i.e., the difference between the rural reference temperature and the maximum temperature observed in the city." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:139 +msgid "run energy savings valuation" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:141 +msgid "Run the energy savings valuation model." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:144 +msgid "run work productivity valuation" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:146 +msgid "Run the work productivity valuation model." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:149 +msgid "average relative humidity" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:152 +msgid "The average relative humidity over the time period of interest. Required if Run Work Productivity Valuation is selected." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:158 +msgid "buildings" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:163 +msgid "Code indicating the building type. These codes must match those in the Energy Consumption Table." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:168 +msgid "A map of built infrastructure footprints. Required if Run Energy Savings Valuation is selected." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:173 +msgid "energy consumption table" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:179 +msgid "Building type codes matching those in the Buildings vector." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:186 +msgid "Energy consumption by footprint area for this building type." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:194 +msgid "The cost of electricity for this building type. If this column is provided, the energy savings outputs will be in the this currency unit rather than kWh." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:202 +msgid "A table of energy consumption data for each building type. Required if Run Energy Savings Valuation is selected." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:207 +msgid "cooling capacity calculation method" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:211 +msgid "factors" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:212 +msgid "Use the weighted shade, albedo, and ETI factors as a temperature predictor (for daytime temperatures)." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:216 +msgid "intensity" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:217 +msgid "Use building intensity as a temperature predictor (for nighttime temperatures)." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:221 +msgid "The air temperature predictor method to use." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:224 +msgid "shade weight" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:227 +msgid "The relative weight to apply to shade when calculating the cooling capacity index. If not provided, defaults to 0.6." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:232 +msgid "albedo weight" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:235 +msgid "The relative weight to apply to albedo when calculating the cooling capacity index. If not provided, defaults to 0.2." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:240 +msgid "evapotranspiration weight" +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:243 +msgid "The relative weight to apply to ETI when calculating the cooling capacity index. If not provided, defaults to 0.2." +msgstr "" + +#: src/natcap/invest/urban_flood_risk_mitigation.py:44 +msgid "Depth of rainfall for the design storm of interest." +msgstr "" + +#: src/natcap/invest/urban_flood_risk_mitigation.py:45 +msgid "rainfall depth" msgstr "" #: src/natcap/invest/urban_flood_risk_mitigation.py:50 msgid "Map of LULC. All values in this raster must have corresponding entries in the Biophysical Table." msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:67 +#: src/natcap/invest/urban_flood_risk_mitigation.py:68 msgid "The curve number value for this LULC type in the soil group code" msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:72 +#: src/natcap/invest/urban_flood_risk_mitigation.py:73 msgid "Table of curve number data for each LULC class. All LULC codes in the LULC raster must have corresponding entries in this table for each soil group." msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:83 +#: src/natcap/invest/urban_flood_risk_mitigation.py:84 msgid "Code indicating the building type. These codes must match those in the Damage Loss Table." msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:89 +#: src/natcap/invest/urban_flood_risk_mitigation.py:90 msgid "Map of building footprints." msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:90 +#: src/natcap/invest/urban_flood_risk_mitigation.py:91 msgid "built infrastructure" msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:97 +#: src/natcap/invest/urban_flood_risk_mitigation.py:99 msgid "Building type code." msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:101 +#: src/natcap/invest/urban_flood_risk_mitigation.py:103 msgid "Potential damage loss for this building type." msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:104 +#: src/natcap/invest/urban_flood_risk_mitigation.py:106 msgid "Table of potential damage loss data for each building type. All values in the Built Infrastructure vector 'type' field must have corresponding entries in this table. Required if the Built Infrastructure vector is provided." msgstr "" -#: src/natcap/invest/urban_flood_risk_mitigation.py:109 +#: src/natcap/invest/urban_flood_risk_mitigation.py:111 msgid "damage loss table" msgstr "" -#: src/natcap/invest/validation.py:30 +#: src/natcap/invest/urban_nature_access.py:130 +msgid "The proportion of the population within each administrative unit belonging to the identified population group (POP_GROUP). At least one column with the prefix 'pop_' is required when aggregating output by population groups." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:139 +msgid "A vector representing administrative units. Polygons representing administrative units should not overlap. Overlapping administrative geometries may cause unexpected results and for this reason should not overlap." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:151 +msgid "The amount of urban nature that each resident should have access to. This is often defined by local urban planning documents." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:163 +msgid "All pixels within the search radius contribute equally to an urban nature pixel." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:169 +msgid "Contributions to an urban nature pixel decrease exponentially, where \"weight = e^(-pixel_dist / search_radius)\"" +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:176 +msgid "Contributions to an urban nature pixel decrease according to a normal (\"gaussian\") distribution with a sigma of 3." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:183 +msgid "Contributions to an urban nature pixel decrease faster as distances approach the search radius. Weights are calculated by \"weight = 0.75 * (1-(pixel_dist / search_radius)^2)\"" +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:210 +msgid "The type of search radius to use." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:216 +msgid "The search radius is the same for all types of urban nature." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:222 +msgid "The search radius is defined for each distinct urban nature LULC classification." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:228 +msgid "The search radius is defined for each distinct population group." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:238 +msgid "Whether to aggregate statistics by population group within each administrative unit. If selected, population groups will be read from the fields of the user-defined administrative boundaries vector. This option is implied if the search radii are defined by population groups." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:252 +msgid "The search radius to use when running the model under a uniform search radius. Required when running the model with a uniform search radius. Units are in meters." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:266 +msgid "The name of the population group. Names must match the names defined in the administrative boundaries vector." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:276 +msgid "The search radius in meters to use for this population group. Values must be >= 0." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:282 +msgid "A table associating population groups with the distance in meters that members of the population group will, on average, travel to find urban nature. Required when running the model with search radii defined per population group." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:418 +msgid "Positive pixel values indicate an oversupply of urban nature for the population group POP_GROUP relative to the stated urban nature demand. Negative values indicate an undersupply of urban nature for the population group POP_GROUP relative to the stated urban nature demand." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:432 +msgid "The area of greenspace available within the defined radius, weighted by the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:442 +msgid "The area of greenspace available within the radius associated with urban nature class LUCODE, weighted by the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:453 +msgid "The area of greenspace available within the radius associated with group POP_GROUP, weighted by the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:467 +msgid "A copy of the user's land use land cover raster. If the user-supplied LULC has non-square pixels, they will be resampled to square pixels in this raster." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:475 +msgid "The user's population raster, aligned to the same resolution and dimensions as the aligned LULC." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:481 +msgid "The population experiencing an urban nature deficit." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:487 +msgid "The population experiencing an urban nature surplus." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:495 +msgid "A sum of the population within the given search radius SEARCH_RADIUS, weighted by the user's decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:505 +msgid "The area of urban nature (in square meters) represented in each pixel." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:514 +msgid "The calculated urban nature/population ratio." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:523 +msgid "Pixel values represent the ares of urban nature (in square meters) represented in each pixel for the urban nature class represented by the land use land cover code LUCODE." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:533 +msgid "The urban nature supplied to populations due to the land use land cover code LUCODE" +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:541 +msgid "The calculated urban nature/population ratio for the urban nature class represented by the land use land cover code LUCODE." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:552 +msgid "Each pixel represents the population of a pixel belonging to the population in the population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:561 +msgid "Each pixel represents the proportion of the total population that belongs to the population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:570 +msgid "Each pixel represents the total number of people within the search radius for the population group POP_GROUP, weighted by the user's selection of decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:580 +msgid "The total population, weighted by the appropriate decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:588 +msgid "The urban nature supply per capita to population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:596 +msgid "The population in population group POP_GROUP that are experiencing an urban nature deficit." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:604 +msgid "The population in population group POP_GROUP that are experiencing an urban nature surplus." +msgstr "" + +#: src/natcap/invest/validation.py:33 msgid "Key is missing from the args dict" msgstr "" -#: src/natcap/invest/validation.py:31 +#: src/natcap/invest/validation.py:34 msgid "Input is required but has no value" msgstr "" -#: src/natcap/invest/validation.py:32 +#: src/natcap/invest/validation.py:35 msgid "Expected the {header} \"{header_name}\" but did not find it" msgstr "" -#: src/natcap/invest/validation.py:34 +#: src/natcap/invest/validation.py:37 +msgid "Expected to find at least one {header} matching the pattern \"{header_name}\" but found none" +msgstr "" + +#: src/natcap/invest/validation.py:40 msgid "Expected the {header} \"{header_name}\" only once but found it {number} times" msgstr "" -#: src/natcap/invest/validation.py:36 +#: src/natcap/invest/validation.py:43 msgid "Value \"{value}\" could not be interpreted as a number" msgstr "" -#: src/natcap/invest/validation.py:37 +#: src/natcap/invest/validation.py:45 msgid "Layer must be projected in this unit: \"{unit_a}\" but found this unit: \"{unit_b}\"" msgstr "" -#: src/natcap/invest/validation.py:39 +#: src/natcap/invest/validation.py:48 msgid "An unexpected error occurred in validation" msgstr "" -#: src/natcap/invest/validation.py:40 +#: src/natcap/invest/validation.py:49 msgid "Directory not found" msgstr "" -#: src/natcap/invest/validation.py:41 +#: src/natcap/invest/validation.py:50 msgid "Path must be a directory" msgstr "" -#: src/natcap/invest/validation.py:42 +#: src/natcap/invest/validation.py:51 msgid "File not found" msgstr "" -#: src/natcap/invest/validation.py:43 +#: src/natcap/invest/validation.py:52 msgid "Dataset must have a valid projection." msgstr "" -#: src/natcap/invest/validation.py:44 +#: src/natcap/invest/validation.py:53 msgid "Dataset must be projected in linear units." msgstr "" -#: src/natcap/invest/validation.py:45 +#: src/natcap/invest/validation.py:54 msgid "File could not be opened as a GDAL raster" msgstr "" -#: src/natcap/invest/validation.py:46 +#: src/natcap/invest/validation.py:55 msgid "File found to be an overview \".ovr\" file." msgstr "" -#: src/natcap/invest/validation.py:47 +#: src/natcap/invest/validation.py:56 msgid "File could not be opened as a GDAL vector" msgstr "" -#: src/natcap/invest/validation.py:48 -msgid "File could not be opened as a CSV or Excel file." -msgstr "" - -#: src/natcap/invest/validation.py:49 -msgid "File could not be opened as a CSV. File must be encoded as a UTF-8 CSV." -msgstr "" - -#: src/natcap/invest/validation.py:51 +#: src/natcap/invest/validation.py:57 msgid "Value did not match expected pattern {regexp}" msgstr "" -#: src/natcap/invest/validation.py:52 +#: src/natcap/invest/validation.py:59 msgid "Value must be one of: {option_list}" msgstr "" -#: src/natcap/invest/validation.py:53 +#: src/natcap/invest/validation.py:60 msgid "Value does not meet condition {condition}" msgstr "" -#: src/natcap/invest/validation.py:54 +#: src/natcap/invest/validation.py:61 msgid "Value {value} is not in the range {range}" msgstr "" -#: src/natcap/invest/validation.py:55 +#: src/natcap/invest/validation.py:62 msgid "Value \"{value}\" does not represent an integer" msgstr "" -#: src/natcap/invest/validation.py:56 +#: src/natcap/invest/validation.py:63 msgid "Value must be either True or False, not {value}" msgstr "" -#: src/natcap/invest/validation.py:57 +#: src/natcap/invest/validation.py:64 msgid "Spatial file {filepath} has no projection" msgstr "" -#: src/natcap/invest/validation.py:58 -msgid "Bounding boxes do not intersect: {bboxes}" +#: src/natcap/invest/validation.py:65 +msgid "Not all of the spatial layers overlap each other. All bounding boxes must intersect: {bboxes}" msgstr "" -#: src/natcap/invest/validation.py:59 +#: src/natcap/invest/validation.py:68 msgid "You must have {permission} access to this file" msgstr "" -#: src/natcap/invest/wave_energy.py:45 +#: src/natcap/invest/validation.py:70 +msgid "Geometry type must be one of {allowed}" +msgstr "" + +#: src/natcap/invest/wave_energy.py:34 +msgid "Index of this percentile bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:38 +msgid "Percentile range within this bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:42 +msgid "Number of pixels whose wave energy values fall into this percentile bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:51 src/natcap/invest/wind_energy.py:331 +msgid "Unique identifier for each point." +msgstr "" + +#: src/natcap/invest/wave_energy.py:55 src/natcap/invest/wind_energy.py:335 +msgid "This is a land connection point" +msgstr "" + +#: src/natcap/invest/wave_energy.py:57 src/natcap/invest/wind_energy.py:337 +msgid "This is a grid connection point" +msgstr "" + +#: src/natcap/invest/wave_energy.py:60 src/natcap/invest/wind_energy.py:340 +msgid "The type of connection at this point." +msgstr "" + +#: src/natcap/invest/wave_energy.py:65 src/natcap/invest/wind_energy.py:345 +msgid "Latitude of the connection point." +msgstr "" + +#: src/natcap/invest/wave_energy.py:70 src/natcap/invest/wind_energy.py:350 +msgid "Longitude of the connection point." +msgstr "" + +#: src/natcap/invest/wave_energy.py:74 +msgid "Name for the connection point location." +msgstr "" + +#: src/natcap/invest/wave_energy.py:149 msgid "Point vector for the west coast of North America and Hawaii." msgstr "" -#: src/natcap/invest/wave_energy.py:52 +#: src/natcap/invest/wave_energy.py:156 msgid "Extract vector for the west coast of North America and Hawaii." msgstr "" -#: src/natcap/invest/wave_energy.py:57 +#: src/natcap/invest/wave_energy.py:161 msgid "WaveWatchIII data for the west coast of North America and Hawaii." msgstr "" -#: src/natcap/invest/wave_energy.py:64 +#: src/natcap/invest/wave_energy.py:168 msgid "Point vector for the East Coast of North America and Puerto Rico." msgstr "" -#: src/natcap/invest/wave_energy.py:71 +#: src/natcap/invest/wave_energy.py:175 msgid "Extract vector for the East Coast of North America and Puerto Rico." msgstr "" -#: src/natcap/invest/wave_energy.py:76 +#: src/natcap/invest/wave_energy.py:180 msgid "WaveWatchIII data for the East Coast of North America and Puerto Rico." msgstr "" -#: src/natcap/invest/wave_energy.py:83 +#: src/natcap/invest/wave_energy.py:187 msgid "Point vector for the North Sea 4 meter resolution." msgstr "" -#: src/natcap/invest/wave_energy.py:89 +#: src/natcap/invest/wave_energy.py:193 msgid "Extract vector for the North Sea 4 meter resolution." msgstr "" -#: src/natcap/invest/wave_energy.py:93 +#: src/natcap/invest/wave_energy.py:197 msgid "WaveWatchIII data for the North Sea 4 meter resolution." msgstr "" -#: src/natcap/invest/wave_energy.py:100 +#: src/natcap/invest/wave_energy.py:204 msgid "Point vector for the North Sea 10 meter resolution." msgstr "" -#: src/natcap/invest/wave_energy.py:106 +#: src/natcap/invest/wave_energy.py:210 msgid "Extract vector for the North Sea 10 meter resolution." msgstr "" -#: src/natcap/invest/wave_energy.py:110 +#: src/natcap/invest/wave_energy.py:214 msgid "WaveWatchIII data for the North Sea 10 meter resolution." msgstr "" -#: src/natcap/invest/wave_energy.py:117 +#: src/natcap/invest/wave_energy.py:221 msgid "Point vector for Australia." msgstr "" -#: src/natcap/invest/wave_energy.py:122 +#: src/natcap/invest/wave_energy.py:226 msgid "Extract vector for Australia." msgstr "" -#: src/natcap/invest/wave_energy.py:125 +#: src/natcap/invest/wave_energy.py:229 msgid "WaveWatchIII data for Australia." msgstr "" -#: src/natcap/invest/wave_energy.py:130 +#: src/natcap/invest/wave_energy.py:234 msgid "Global point vector." msgstr "" -#: src/natcap/invest/wave_energy.py:135 +#: src/natcap/invest/wave_energy.py:239 msgid "Global extract vector." msgstr "" -#: src/natcap/invest/wave_energy.py:138 +#: src/natcap/invest/wave_energy.py:242 msgid "Global WaveWatchIII data." msgstr "" -#: src/natcap/invest/wave_energy.py:140 +#: src/natcap/invest/wave_energy.py:244 msgid "Pre-packaged wave energy data directory. This is provided with the sample data." msgstr "" -#: src/natcap/invest/wave_energy.py:143 +#: src/natcap/invest/wave_energy.py:247 msgid "wave base data" msgstr "" -#: src/natcap/invest/wave_energy.py:148 +#: src/natcap/invest/wave_energy.py:252 msgid "West Coast of North America and Hawaii" msgstr "" -#: src/natcap/invest/wave_energy.py:150 +#: src/natcap/invest/wave_energy.py:254 msgid "East Coast of North America and Puerto Rico" msgstr "" -#: src/natcap/invest/wave_energy.py:153 +#: src/natcap/invest/wave_energy.py:257 msgid "North Sea 4 meter resolution" msgstr "" -#: src/natcap/invest/wave_energy.py:155 +#: src/natcap/invest/wave_energy.py:259 msgid "North Sea 10 meter resolution" msgstr "" -#: src/natcap/invest/wave_energy.py:156 +#: src/natcap/invest/wave_energy.py:260 msgid "Australia" msgstr "" -#: src/natcap/invest/wave_energy.py:157 +#: src/natcap/invest/wave_energy.py:261 msgid "Global" msgstr "" -#: src/natcap/invest/wave_energy.py:159 +#: src/natcap/invest/wave_energy.py:263 msgid "The analysis area over which to run the model." msgstr "" -#: src/natcap/invest/wave_energy.py:161 +#: src/natcap/invest/wave_energy.py:265 msgid "analysis area" msgstr "" -#: src/natcap/invest/wave_energy.py:171 +#: src/natcap/invest/wave_energy.py:275 msgid "A matrix of the wave machine performance, or ability to capture wave energy, in different sea state conditions. The first column contains wave height values (in meters, increasing from top to bottom), and the first row contains wave period values (in seconds, increasing from left to right). Values within the matrix are the machine performance in kilowatts at that sea state condition, described by the wave height (row) and wave period (column). The model linearly interpolates sea state data from the base wave dataset onto this matrix to determine performance." msgstr "" -#: src/natcap/invest/wave_energy.py:182 +#: src/natcap/invest/wave_energy.py:286 msgid "machine performance table" msgstr "" -#: src/natcap/invest/wave_energy.py:188 -msgid "Maximum capacity for device." +#: src/natcap/invest/wave_energy.py:295 +msgid "Name of the machine parameter. Expected parameters are: 'capmax' (maximum capacity for device, in kilowatts), 'hsmax' (upper limit of wave height for device operation, in meters), and 'tpmax' (upper limit of wave period for device operation, in seconds)." msgstr "" -#: src/natcap/invest/wave_energy.py:193 -msgid "Upper limit of wave height for device operation. The device shuts down when waves are higher than this." -msgstr "" - -#: src/natcap/invest/wave_energy.py:200 -msgid "Upper limit of wave period for device operation. The device shuts down when the wave period is longer than this." +#: src/natcap/invest/wave_energy.py:305 src/natcap/invest/wave_energy.py:354 +msgid "Value of the machine parameter." msgstr "" -#: src/natcap/invest/wave_energy.py:208 +#: src/natcap/invest/wave_energy.py:308 msgid "Table of parameters for the wave energy machine in use." msgstr "" -#: src/natcap/invest/wave_energy.py:209 +#: src/natcap/invest/wave_energy.py:309 msgid "machine parameter table" msgstr "" -#: src/natcap/invest/wave_energy.py:212 src/natcap/invest/wind_energy.py:100 +#: src/natcap/invest/wave_energy.py:312 src/natcap/invest/wind_energy.py:128 msgid "bathymetry" msgstr "" -#: src/natcap/invest/wave_energy.py:215 src/natcap/invest/wind_energy.py:99 +#: src/natcap/invest/wave_energy.py:315 src/natcap/invest/wind_energy.py:127 msgid "Map of ocean depth. Values should be negative." msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:122 -#: src/natcap/invest/wave_energy.py:220 +#: src/natcap/invest/scenic_quality/scenic_quality.py:121 +#: src/natcap/invest/wave_energy.py:320 msgid "Run the valuation model." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:348 -#: src/natcap/invest/scenic_quality/scenic_quality.py:119 -#: src/natcap/invest/wave_energy.py:221 src/natcap/invest/wind_energy.py:282 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:353 +#: src/natcap/invest/scenic_quality/scenic_quality.py:118 +#: src/natcap/invest/wave_energy.py:321 src/natcap/invest/wind_energy.py:310 msgid "run valuation" msgstr "" -#: src/natcap/invest/wave_energy.py:228 src/natcap/invest/wind_energy.py:302 -msgid "Unique identifier for each point." -msgstr "" - -#: src/natcap/invest/wave_energy.py:232 src/natcap/invest/wind_energy.py:306 -msgid "This is a land connection point" +#: src/natcap/invest/wave_energy.py:327 +msgid "A table of data for each connection point. Required if Run Valuation is selected." msgstr "" -#: src/natcap/invest/wave_energy.py:234 src/natcap/invest/wind_energy.py:308 -msgid "This is a grid connection point" +#: src/natcap/invest/wave_energy.py:330 +msgid "grid connection points table" msgstr "" -#: src/natcap/invest/wave_energy.py:237 src/natcap/invest/wind_energy.py:311 -msgid "The type of connection at this point." +#: src/natcap/invest/wave_energy.py:339 +msgid "Name of the machine parameter. Expected parameters are: 'capmax' (maximum capacity for device, in kilowatts), 'cc' (capital cost per device installed, $/kilowatt), 'cml' (cost of mooring lines, $/kilometer), 'cul' (cost of underwater cable, $/kilometer), 'col' (cost of overland transmission lines, $/kilometer), 'omc' (operating and maintenance cost, $/kilowatt hour), 'p' (price of electricity, $/kilowatt hour), 'r' (discount rate, between 0 and 1), 'smlpm' (number of slack lines required per machine)" msgstr "" -#: src/natcap/invest/wave_energy.py:242 src/natcap/invest/wind_energy.py:316 -msgid "Latitude of the connection point." +#: src/natcap/invest/wave_energy.py:358 +msgid "Table of economic parameters for the wave energy machine. Required if Run Valuation is selected." msgstr "" -#: src/natcap/invest/wave_energy.py:247 src/natcap/invest/wind_energy.py:321 -msgid "Longitude of the connection point." +#: src/natcap/invest/wave_energy.py:361 +msgid "machine economic table" msgstr "" -#: src/natcap/invest/wave_energy.py:251 -msgid "Name for the connection point location." +#: src/natcap/invest/wave_energy.py:368 +msgid "Number of wave machines to model. Required if Run Valuation is selected." msgstr "" -#: src/natcap/invest/wave_energy.py:255 -msgid "A table of data for each connection point. Required if Run Valuation is selected." +#: src/natcap/invest/wave_energy.py:371 +msgid "number of machines" msgstr "" -#: src/natcap/invest/wave_energy.py:258 -msgid "grid connection points table" +#: src/natcap/invest/wave_energy.py:379 +msgid "Map of captured wave energy per WEC device." msgstr "" -#: src/natcap/invest/wave_energy.py:266 -msgid "Maximum capacity of the device." +#: src/natcap/invest/wave_energy.py:387 +msgid "Map of captured wave energy per WEC device reclassified by quantiles (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." msgstr "" -#: src/natcap/invest/wave_energy.py:271 -msgid "Capital cost per device installed." +#: src/natcap/invest/wave_energy.py:394 +msgid "Table of value ranges for each captured wave energy quantile group as well as the number of pixels for each group." msgstr "" -#: src/natcap/invest/wave_energy.py:276 -msgid "Cost of mooring lines." +#: src/natcap/invest/wave_energy.py:404 +msgid "Range of wave energy values within this percentile bin." msgstr "" -#: src/natcap/invest/wave_energy.py:281 -msgid "Cost of underwater cable." +#: src/natcap/invest/wave_energy.py:412 +msgid "Vector map of the provided grid points" msgstr "" -#: src/natcap/invest/wave_energy.py:286 -msgid "Cost of overland transmission lines." +#: src/natcap/invest/wave_energy.py:418 +msgid "Vector map of the provided land points" msgstr "" -#: src/natcap/invest/wave_energy.py:291 -msgid "Operating and maintenance cost." +#: src/natcap/invest/wave_energy.py:423 +msgid "Map of positive values of net present value over the 25-year lifespan of a wave energy facility, reclassified by quantiles (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." msgstr "" -#: src/natcap/invest/wave_energy.py:296 -msgid "Price of electricity." +#: src/natcap/invest/wave_energy.py:431 +msgid "Table of value ranges for each net present value quantile group as well as the number of pixels for each group." msgstr "" -#: src/natcap/invest/wave_energy.py:300 -msgid "Discount rate." +#: src/natcap/invest/wave_energy.py:441 +msgid "Range of net present values within this percentile bin." msgstr "" -#: src/natcap/invest/wave_energy.py:305 -msgid "Number of slack lines required per machine." +#: src/natcap/invest/wave_energy.py:448 +msgid "Map of net present value over the 25-year lifespan of a wave energy facility." msgstr "" -#: src/natcap/invest/wave_energy.py:310 -msgid "Table of economic parameters for the wave energy machine. Required if Run Valuation is selected." +#: src/natcap/invest/wave_energy.py:457 +msgid "Map of potential wave power." msgstr "" -#: src/natcap/invest/wave_energy.py:313 -msgid "machine economic table" +#: src/natcap/invest/wave_energy.py:464 +msgid "Map of potential wave power classified into quantiles (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." msgstr "" -#: src/natcap/invest/wave_energy.py:320 -msgid "Number of wave machines to model. Required if Run Valuation is selected." +#: src/natcap/invest/wave_energy.py:471 +msgid "Table of value ranges for each wave power quantile group as well as the number of pixels for each group." msgstr "" -#: src/natcap/invest/wave_energy.py:323 -msgid "number of machines" +#: src/natcap/invest/wave_energy.py:480 +msgid "Range of potential wave power values within this percentile bin." msgstr "" -#: src/natcap/invest/wind_energy.py:55 +#: src/natcap/invest/wind_energy.py:36 msgid "Longitude of the data point." msgstr "" -#: src/natcap/invest/wind_energy.py:60 +#: src/natcap/invest/wind_energy.py:41 msgid "Latitude of the data point." msgstr "" -#: src/natcap/invest/wind_energy.py:65 +#: src/natcap/invest/wind_energy.py:46 src/natcap/invest/wind_energy.py:76 msgid "Weibull scale factor at the reference hub height at this point." msgstr "" -#: src/natcap/invest/wind_energy.py:72 +#: src/natcap/invest/wind_energy.py:53 msgid "Weibull shape factor at this point." msgstr "" -#: src/natcap/invest/wind_energy.py:77 +#: src/natcap/invest/wind_energy.py:58 msgid "The reference hub height at this point, at which wind speed data was collected and LAM was estimated." msgstr "" -#: src/natcap/invest/wind_energy.py:82 -msgid "Table of Weibull parameters for each wind data point." +#: src/natcap/invest/wind_energy.py:69 +msgid "Weibull scale factor calculated for the proposed hub height at this point." msgstr "" #: src/natcap/invest/wind_energy.py:83 +msgid "Power density at this point." +msgstr "" + +#: src/natcap/invest/wind_energy.py:88 +msgid "Predicted energy harvested from a wind farm centered on this point." +msgstr "" + +#: src/natcap/invest/wind_energy.py:110 +msgid "Table of Weibull parameters for each wind data point." +msgstr "" + +#: src/natcap/invest/wind_energy.py:111 msgid "wind data points" msgstr "" -#: src/natcap/invest/wind_energy.py:90 +#: src/natcap/invest/wind_energy.py:118 msgid "Map of the area(s) of interest over which to run the model and aggregate valuation results. Required if Run Valuation is selected and the Grid Connection Points table is provided." msgstr "" -#: src/natcap/invest/wind_energy.py:107 +#: src/natcap/invest/wind_energy.py:135 msgid "Map of the coastlines of landmasses in the area of interest. Required if the Minimum Distance and Maximum Distance inputs are provided." msgstr "" -#: src/natcap/invest/wind_energy.py:111 +#: src/natcap/invest/wind_energy.py:139 msgid "land polygon" msgstr "" -#: src/natcap/invest/wind_energy.py:119 +#: src/natcap/invest/wind_energy.py:147 msgid "Standard atmosphere air density." msgstr "" -#: src/natcap/invest/wind_energy.py:123 +#: src/natcap/invest/wind_energy.py:151 msgid "Exponent to use in the power curve function." msgstr "" -#: src/natcap/invest/wind_energy.py:126 +#: src/natcap/invest/wind_energy.py:154 msgid "Cost to decommission a turbine as a proportion of the total upfront costs (cables, foundations, installation?)" msgstr "" -#: src/natcap/invest/wind_energy.py:133 +#: src/natcap/invest/wind_energy.py:161 msgid "The operations and maintenance costs as a proportion of capex_arr" msgstr "" -#: src/natcap/invest/wind_energy.py:138 +#: src/natcap/invest/wind_energy.py:166 msgid "The miscellaneous costs as a proportion of capex_arr" msgstr "" -#: src/natcap/invest/wind_energy.py:143 +#: src/natcap/invest/wind_energy.py:171 msgid "The installation costs as a proportion of capex_arr" msgstr "" -#: src/natcap/invest/wind_energy.py:149 +#: src/natcap/invest/wind_energy.py:177 msgid "The length of infield cable." msgstr "" -#: src/natcap/invest/wind_energy.py:153 +#: src/natcap/invest/wind_energy.py:181 msgid "The cost of infield cable." msgstr "" -#: src/natcap/invest/wind_energy.py:157 +#: src/natcap/invest/wind_energy.py:185 msgid "Cost of AC cable that scales with capacity." msgstr "" -#: src/natcap/invest/wind_energy.py:161 +#: src/natcap/invest/wind_energy.py:189 msgid "Cost of DC cable that scales with capacity." msgstr "" -#: src/natcap/invest/wind_energy.py:165 +#: src/natcap/invest/wind_energy.py:193 msgid "Cost of AC cable that scales with length." msgstr "" -#: src/natcap/invest/wind_energy.py:169 +#: src/natcap/invest/wind_energy.py:197 msgid "Cost of DC cable that scales with length." msgstr "" -#: src/natcap/invest/wind_energy.py:173 +#: src/natcap/invest/wind_energy.py:201 msgid "The threshold above which a wind farm’s distance from the grid requires a switch from AC to DC power to overcome line losses which reduce the amount of energy delivered" msgstr "" -#: src/natcap/invest/wind_energy.py:181 +#: src/natcap/invest/wind_energy.py:209 msgid "The expected lifetime of the facility" msgstr "" -#: src/natcap/invest/wind_energy.py:185 +#: src/natcap/invest/wind_energy.py:213 msgid "Factor that translates carbon-free wind power to a corresponding amount of avoided CO2 emissions" msgstr "" -#: src/natcap/invest/wind_energy.py:191 +#: src/natcap/invest/wind_energy.py:219 msgid "The reduction in air density per meter above sea level" msgstr "" -#: src/natcap/invest/wind_energy.py:196 +#: src/natcap/invest/wind_energy.py:224 msgid "The fraction of energy lost due to downtime, power conversion inefficiency, and electrical grid losses" msgstr "" -#: src/natcap/invest/wind_energy.py:200 +#: src/natcap/invest/wind_energy.py:228 msgid "A table of wind energy infrastructure parameters." msgstr "" -#: src/natcap/invest/wind_energy.py:202 +#: src/natcap/invest/wind_energy.py:230 msgid "global wind energy parameters" msgstr "" -#: src/natcap/invest/wind_energy.py:210 +#: src/natcap/invest/wind_energy.py:238 msgid "Height of the turbine hub above sea level." msgstr "" -#: src/natcap/invest/wind_energy.py:214 +#: src/natcap/invest/wind_energy.py:242 msgid "Wind speed at which the turbine begins producing power." msgstr "" -#: src/natcap/invest/wind_energy.py:220 +#: src/natcap/invest/wind_energy.py:248 msgid "Minimum wind speed at which the turbine reaches its rated power output." msgstr "" -#: src/natcap/invest/wind_energy.py:226 +#: src/natcap/invest/wind_energy.py:254 msgid "Wind speed above which the turbine stops generating power for safety reasons." msgstr "" -#: src/natcap/invest/wind_energy.py:232 +#: src/natcap/invest/wind_energy.py:260 msgid "The turbine's rated power output." msgstr "" -#: src/natcap/invest/wind_energy.py:236 +#: src/natcap/invest/wind_energy.py:264 msgid "The cost of one turbine." msgstr "" -#: src/natcap/invest/wind_energy.py:238 +#: src/natcap/invest/wind_energy.py:266 msgid "A table of parameters specific to the type of turbine." msgstr "" -#: src/natcap/invest/wind_energy.py:239 +#: src/natcap/invest/wind_energy.py:267 msgid "turbine parameters" msgstr "" -#: src/natcap/invest/wind_energy.py:245 +#: src/natcap/invest/wind_energy.py:273 msgid "The number of wind turbines per wind farm." msgstr "" -#: src/natcap/invest/wind_energy.py:246 +#: src/natcap/invest/wind_energy.py:274 msgid "number of turbines" msgstr "" -#: src/natcap/invest/wind_energy.py:251 +#: src/natcap/invest/wind_energy.py:279 msgid "Minimum depth for offshore wind farm installation." msgstr "" -#: src/natcap/invest/wind_energy.py:252 +#: src/natcap/invest/wind_energy.py:280 msgid "minimum depth" msgstr "" -#: src/natcap/invest/wind_energy.py:257 +#: src/natcap/invest/wind_energy.py:285 msgid "Maximum depth for offshore wind farm installation." msgstr "" -#: src/natcap/invest/wind_energy.py:258 +#: src/natcap/invest/wind_energy.py:286 msgid "maximum depth" msgstr "" -#: src/natcap/invest/wind_energy.py:264 +#: src/natcap/invest/wind_energy.py:292 msgid "Minimum distance from shore for offshore wind farm installation. Required if Run Valuation is selected." msgstr "" -#: src/natcap/invest/wind_energy.py:267 +#: src/natcap/invest/wind_energy.py:295 msgid "minimum distance" msgstr "" -#: src/natcap/invest/wind_energy.py:273 +#: src/natcap/invest/wind_energy.py:301 msgid "Maximum distance from shore for offshore wind farm installation. Required if Run Valuation is selected." msgstr "" -#: src/natcap/invest/wind_energy.py:276 +#: src/natcap/invest/wind_energy.py:304 msgid "maximum distance" msgstr "" -#: src/natcap/invest/wind_energy.py:281 +#: src/natcap/invest/wind_energy.py:309 msgid "Run the valuation component of the model." msgstr "" -#: src/natcap/invest/wind_energy.py:288 +#: src/natcap/invest/wind_energy.py:316 msgid "The cost of the foundation for one turbine." msgstr "" -#: src/natcap/invest/wind_energy.py:289 +#: src/natcap/invest/wind_energy.py:317 msgid "foundation cost" msgstr "" -#: src/natcap/invest/wind_energy.py:294 +#: src/natcap/invest/wind_energy.py:322 msgid "Annual discount rate to apply to valuation." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:402 -#: src/natcap/invest/wind_energy.py:295 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:408 +#: src/natcap/invest/wind_energy.py:323 msgid "discount rate" msgstr "" -#: src/natcap/invest/wind_energy.py:325 +#: src/natcap/invest/wind_energy.py:354 msgid "Table of grid and land connection points to which cables will connect. Required if Run Valuation is selected and Average Shore-to-Grid Distance is not provided." msgstr "" -#: src/natcap/invest/wind_energy.py:329 +#: src/natcap/invest/wind_energy.py:358 msgid "grid connection points" msgstr "" -#: src/natcap/invest/wind_energy.py:336 +#: src/natcap/invest/wind_energy.py:365 msgid "Average distance to the onshore grid from coastal cable landing points. Required if Run Valuation is selected and the Grid Connection Points table is not provided." msgstr "" -#: src/natcap/invest/wind_energy.py:340 +#: src/natcap/invest/wind_energy.py:369 msgid "average shore-to-grid distance" msgstr "" -#: src/natcap/invest/wind_energy.py:345 +#: src/natcap/invest/wind_energy.py:374 msgid "Use a Wind Energy Price Table instead of calculating annual prices from the initial Energy Price and Rate of Price Change inputs." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:357 -#: src/natcap/invest/wind_energy.py:349 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:362 +#: src/natcap/invest/wind_energy.py:378 msgid "use price table" msgstr "" -#: src/natcap/invest/wind_energy.py:357 +#: src/natcap/invest/wind_energy.py:387 msgid "Consecutive years for each year in the lifespan of the wind farm. These may be the actual years: 2010, 2011, 2012..., or the number of the years after the starting date: 1, 2, 3,..." msgstr "" -#: src/natcap/invest/wind_energy.py:366 +#: src/natcap/invest/wind_energy.py:396 msgid "Price of energy for each year." msgstr "" -#: src/natcap/invest/wind_energy.py:370 +#: src/natcap/invest/wind_energy.py:400 msgid "Table of yearly prices for wind energy. There must be a row for each year in the lifespan given in the 'time_period' column in the Global Wind Energy Parameters table. Required if Run Valuation and Use Price Table are selected." msgstr "" -#: src/natcap/invest/wind_energy.py:375 +#: src/natcap/invest/wind_energy.py:405 msgid "wind energy price table" msgstr "" -#: src/natcap/invest/wind_energy.py:381 +#: src/natcap/invest/wind_energy.py:411 msgid "The initial price of wind energy, at the first year in the wind energy farm lifespan. Required if Run Valuation is selected and Use Price Table is not selected." msgstr "" -#: src/natcap/invest/wind_energy.py:385 +#: src/natcap/invest/wind_energy.py:415 msgid "price of energy" msgstr "" -#: src/natcap/invest/wind_energy.py:390 +#: src/natcap/invest/wind_energy.py:420 msgid "The annual rate of change in the price of wind energy. Required if Run Valuation is selected and Use Price Table is not selected." msgstr "" -#: src/natcap/invest/wind_energy.py:394 +#: src/natcap/invest/wind_energy.py:424 msgid "rate of price change" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:115 +#: src/natcap/invest/wind_energy.py:432 +msgid "Map of offset carbon emissions for a farm centered on each pixel" +msgstr "" + +#: src/natcap/invest/wind_energy.py:441 +msgid "Map of power density." +msgstr "" + +#: src/natcap/invest/wind_energy.py:448 +msgid "Map of energy harvested from a farm centered on each pixel." +msgstr "" + +#: src/natcap/invest/wind_energy.py:456 +msgid "Map of the energy price that would be required to set the present value of a farm centered on each pixel equal to zero." +msgstr "" + +#: src/natcap/invest/wind_energy.py:466 +msgid "Map of the net present value of a farm centered on each pixel." +msgstr "" + +#: src/natcap/invest/wind_energy.py:471 +msgid "Map of summarized data at each point." +msgstr "" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:116 msgid "Analysis year {analysis_year} must be >= the latest snapshot year ({latest_year})" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:118 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:119 msgid "Raster for snapshot {snapshot_year} could not be validated." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:174 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:121 +msgid "The transition table expects values of {model_transitions} but found values of {transition_values}." +msgstr "" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:177 msgid "The snapshot year that this row's LULC raster represents. Each year in this table must be unique." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:181 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:184 msgid "Map of LULC in the given snapshot year. All values in this raster must have corresponding entries in the Biophysical Table and Landcover Transitions Table." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:188 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:191 msgid "A table mapping snapshot years to corresponding LULC maps." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:190 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:193 msgid "landcover snapshots table" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:196 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:199 msgid "analysis year" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:197 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:200 msgid "A year that may be used to extend the analysis beyond the last snapshot year. If used, the model assumes that carbon will continue to accumulate or emit after the last snapshot year until the analysis year. This value must be greater than the final snapshot year." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:210 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:214 msgid "The LULC code that represents this LULC class in the LULC snapshot rasters." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:215 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:219 msgid "Name of the LULC class. This label must be unique among the all the LULC classes." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:221 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:225 msgid "The initial carbon stocks in the biomass pool for this LULC class." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:227 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:231 msgid "The initial carbon stocks in the soil pool for this LULC class." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:233 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:237 msgid "The initial carbon stocks in the litter pool for this LULC class." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:240 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:244 msgid "The half-life of carbon in the biomass pool." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:243 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:247 msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a low-impact disturbance." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:249 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:253 msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a medium-impact disturbance." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:255 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:259 msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a high-impact disturbance." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:262 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:266 msgid "Annual rate of CO2E accumulation in the biomass pool." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:268 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:272 msgid "The half-life of carbon in the soil pool." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:271 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:275 msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a low-impact disturbance." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:277 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:281 msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a medium-impact disturbance." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:283 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:287 msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a high-impact disturbance." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:290 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:294 msgid "Annual rate of CO2E accumulation in the soil pool." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:295 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:299 msgid "Annual rate of CO2E accumulation in the litter pool." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:298 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:302 msgid "Table of biophysical properties for each LULC class." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:301 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:305 msgid "landcover transitions table" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:306 -msgid "LULC codes matching the codes in the biophysical table." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:311 +msgid "LULC class names matching those in the biophysical table." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:313 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:318 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:97 msgid "a state of carbon accumulation" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:316 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:321 msgid "high carbon disturbance rate" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:319 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:324 msgid "medium carbon disturbance rate" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:322 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:327 msgid "low carbon disturbance rate" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:325 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:330 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:106 msgid "no change in carbon" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:328 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:333 msgid "A transition matrix describing the type of carbon action that occurs when each LULC type transitions to each other type. Values in the first column, 'lulc-class', represents the original LULC class that is transitioned away from. Values in the first row represents the LULC class that is transitioned to. Each cell in the matrix is filled with an option indicating the effect on carbon when transitioning from that cell's row's LULC class to that cell's column's LULC class. The classes in this table must exactly match the classes in the Biophysical Table 'lulc-class' column. A cell may be left empty if the transition never occurs." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:343 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:348 msgid "A transition matrix mapping the type of carbon action undergone when one LULC type transitions to another." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:351 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:356 msgid "Enable net present valuation analysis based on carbon prices from either a yearly price table, or an initial price and yearly interest rate." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:360 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:365 msgid "Use a yearly price table, rather than an initial price and interest rate, to indicate carbon value over time." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:365 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:370 msgid "price" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:369 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:374 msgid "The price of CO2E at the baseline year. Required if Do Valuation is selected and Use Price Table is not selected." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:374 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:379 msgid "interest rate" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:377 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:382 msgid "Annual increase in the price of CO2E. Required if Do Valuation is selected and Use Price Table is not selected." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:382 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:387 msgid "price table" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:389 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:395 msgid "Each year from the snapshot year to analysis year." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:394 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:400 msgid "Price of CO2E in that year." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:396 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:402 msgid "Table of annual CO2E prices for each year from the baseline year to the final snapshot or analysis year. Required if Do Valuation is selected and Use Price Table is selected." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:405 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:411 msgid "Annual discount rate on the price of carbon. This is compounded each year after the baseline year. Required if Run Valuation is selected." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:30 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:33 msgid "LULC lookup table" msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:32 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:35 msgid "A table mapping LULC codes from the snapshot rasters to the corresponding LULC class names, and whether or not the class is a coastal blue carbon habitat." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:39 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:43 msgid "LULC code. Every value in the snapshot LULC maps must have a corresponding entry in this column." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:45 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:49 msgid "Name of the LULC class." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:48 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:52 msgid "Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if not." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:59 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:63 msgid "Year to snapshot." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:63 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:67 msgid "Map of LULC in the snapshot year. All values in this raster must have corresponding entries in the LULC Lookup table." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:69 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:73 msgid "A table mapping snapshot years to corresponding LULC maps for each year." msgstr "" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:72 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:76 msgid "LULC snapshots table" msgstr "" +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:90 +msgid "LULC codes matching the codes in the biophysical table." +msgstr "" + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:100 +msgid "Carbon disturbance occurred. Replace this with one of ‘low-impact-disturb’, ‘med-impact-disturb’, or ‘high-impact-disturb’ to indicate the degree of disturbance." +msgstr "" + #: src/natcap/invest/delineateit/delineateit.py:46 msgid "Detect pour points (watershed outlets) based on the DEM, and use these instead of a user-provided outlet features vector." msgstr "" @@ -2602,83 +3031,83 @@ msgstr "" msgid "skip invalid geometries" msgstr "" -#: src/natcap/invest/ndr/ndr.py:25 +#: src/natcap/invest/ndr/ndr.py:26 msgid "Either calc_n or calc_p must be True" msgstr "" -#: src/natcap/invest/ndr/ndr.py:47 +#: src/natcap/invest/ndr/ndr.py:48 msgid "All values in this raster must have corresponding entries in the Biophysical table." msgstr "" -#: src/natcap/invest/ndr/ndr.py:57 +#: src/natcap/invest/ndr/ndr.py:58 msgid "Map of runoff potential, the capacity to transport nutrients downslope. This can be a quickflow index or annual precipitation. Any units are allowed since the values will be normalized by their average." msgstr "" -#: src/natcap/invest/ndr/ndr.py:62 +#: src/natcap/invest/ndr/ndr.py:63 msgid "nutrient runoff proxy" msgstr "" -#: src/natcap/invest/ndr/ndr.py:69 +#: src/natcap/invest/ndr/ndr.py:70 msgid "Map of the boundaries of the watershed(s) over which to aggregate the model results." msgstr "" -#: src/natcap/invest/ndr/ndr.py:81 +#: src/natcap/invest/ndr/ndr.py:83 msgid "The nutrient loading for this land use class." msgstr "" -#: src/natcap/invest/ndr/ndr.py:85 +#: src/natcap/invest/ndr/ndr.py:87 msgid "Maximum nutrient retention efficiency. This is the maximum proportion of the nutrient that is retained on this LULC class." msgstr "" -#: src/natcap/invest/ndr/ndr.py:92 +#: src/natcap/invest/ndr/ndr.py:94 msgid "The distance after which it is assumed that this LULC type retains the nutrient at its maximum capacity. If nutrients travel a shorter distance that this, the retention efficiency will be less than the maximum value eff_x, following an exponential decay." msgstr "" -#: src/natcap/invest/ndr/ndr.py:102 +#: src/natcap/invest/ndr/ndr.py:104 msgid "The proportion of the total amount of nitrogen that are dissolved into the subsurface. By default, this value should be set to 0, indicating that all nutrients are delivered via surface flow. There is no equivalent of this for phosphorus." msgstr "" -#: src/natcap/invest/ndr/ndr.py:109 +#: src/natcap/invest/ndr/ndr.py:111 msgid "A table mapping each LULC class to its biophysical properties related to nutrient load and retention. Replace '[NUTRIENT]' in the column names with 'n' or 'p' for nitrogen or phosphorus respectively. Nitrogen data must be provided if Calculate Nitrogen is selected. Phosphorus data must be provided if Calculate Phosphorus is selected. All LULC codes in the LULC raster must have corresponding entries in this table." msgstr "" -#: src/natcap/invest/ndr/ndr.py:122 +#: src/natcap/invest/ndr/ndr.py:124 msgid "Calculate phosphorus retention and export." msgstr "" -#: src/natcap/invest/ndr/ndr.py:123 +#: src/natcap/invest/ndr/ndr.py:125 msgid "calculate phosphorus" msgstr "" -#: src/natcap/invest/ndr/ndr.py:127 +#: src/natcap/invest/ndr/ndr.py:129 msgid "Calculate nitrogen retention and export." msgstr "" -#: src/natcap/invest/ndr/ndr.py:128 +#: src/natcap/invest/ndr/ndr.py:130 msgid "calculate nitrogen" msgstr "" -#: src/natcap/invest/ndr/ndr.py:136 +#: src/natcap/invest/ndr/ndr.py:138 msgid "Calibration parameter that determines the shape of the relationship between hydrologic connectivity (the degree of connection from patches of land to the stream) and the nutrient delivery ratio (percentage of nutrient that actually reaches the stream)." msgstr "" -#: src/natcap/invest/ndr/ndr.py:142 src/natcap/invest/sdr/sdr.py:110 +#: src/natcap/invest/ndr/ndr.py:144 src/natcap/invest/sdr/sdr.py:112 msgid "Borselli k parameter" msgstr "" -#: src/natcap/invest/ndr/ndr.py:148 +#: src/natcap/invest/ndr/ndr.py:150 msgid "subsurface critical length (nitrogen)" msgstr "" -#: src/natcap/invest/ndr/ndr.py:149 +#: src/natcap/invest/ndr/ndr.py:151 msgid "The distance traveled (subsurface and downslope) after which it is assumed that soil retains nitrogen at its maximum capacity. Required if Calculate Nitrogen is selected." msgstr "" -#: src/natcap/invest/ndr/ndr.py:157 +#: src/natcap/invest/ndr/ndr.py:159 msgid "subsurface maximum retention efficiency (nitrogen)" msgstr "" -#: src/natcap/invest/ndr/ndr.py:158 +#: src/natcap/invest/ndr/ndr.py:160 msgid "The maximum nitrogen retention efficiency that can be reached through subsurface flow. This characterizes the retention due to biochemical degradation in soils. Required if Calculate Nitrogen is selected." msgstr "" @@ -2707,7 +3136,7 @@ msgid "Predictor is a point vector. Metric is the number of points within each A msgstr "" #: src/natcap/invest/recreation/recmodel_client.py:78 -msgid "Predictor is a point vector. Metric is the Euclidean distance between the center of each AOI grid cell and the nearest point in this layer." +msgid "Predictor is a point vector. Metric is the Euclidean distance between the centroid of each AOI grid cell and the nearest point in this layer." msgstr "" #: src/natcap/invest/recreation/recmodel_client.py:83 @@ -2798,203 +3227,432 @@ msgstr "" msgid "compute regression" msgstr "" -#: src/natcap/invest/recreation/recmodel_client.py:197 +#: src/natcap/invest/recreation/recmodel_client.py:198 msgid "A table that maps predictor IDs to spatial files and their predictor metric types. The file paths can be absolute or relative to the table." msgstr "" -#: src/natcap/invest/recreation/recmodel_client.py:201 +#: src/natcap/invest/recreation/recmodel_client.py:202 msgid "predictor table" msgstr "" -#: src/natcap/invest/recreation/recmodel_client.py:207 +#: src/natcap/invest/recreation/recmodel_client.py:209 msgid "A table of future or alternative scenario predictors. Maps IDs to files and their types. The file paths can be absolute or relative to the table." msgstr "" -#: src/natcap/invest/recreation/recmodel_client.py:211 +#: src/natcap/invest/recreation/recmodel_client.py:213 msgid "scenario predictor table" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:67 +#: src/natcap/invest/recreation/recmodel_client.py:218 +msgid "Copy of the the AOI vector with aggregate attributes added." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:223 +msgid "The average photo-user-days per year" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:229 +msgid "The average photo-user-days for each month." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:237 +msgid "Table of monthly photo-user-days." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:242 +msgid "Polygon ID" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:245 +msgid "Total photo-user-days counted in each cell in the given month." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:255 +msgid "AOI polygons with their corresponding predictor attributes." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:262 +#: src/natcap/invest/recreation/recmodel_client.py:287 +msgid "Predictor attribute value for each polygon." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:269 +msgid "This is a text file output of the regression analysis. It includes estimates for each predictor variable. It also contains a “server id hash” value which can be used to correlate the PUD result with the data available on the PUD server. If these results are used in publication this hash should be included with the results for reproducibility." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:279 +msgid "AOI polygons with their corresponding predictor attributes in the scenario." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:293 +msgid "The estimated PUD_YR_AVG per polygon." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:301 +msgid "Copy of the input AOI, gridded if applicable." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:307 +msgid "Compressed AOI" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:310 +msgid "aggregated predictor values within each polygon" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:314 +msgid "Predictor estimates" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:317 +msgid "Compressed photo-user-day data" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:319 +msgid "Pickled dictionary mapping FIDs to shapely geometries" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:326 +msgid "aggregated scenario predictor values within each polygon" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:333 +msgid "Server version info" +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:66 msgid "features impacting scenic quality" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:75 +#: src/natcap/invest/scenic_quality/scenic_quality.py:74 msgid "Maximum length of the line of sight originating from a viewpoint. The value can either be positive (preferred) or negative (kept for backwards compatibility), but is converted to a positive number. If this field is not provided, the model will include all pixels in the DEM in the visibility analysis. RADIUS preferred, but may also be called RADIUS2 for backwards compatibility." msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:88 +#: src/natcap/invest/scenic_quality/scenic_quality.py:87 msgid "Viewshed importance coefficient. If this field is provided, the values are used to weight each feature's viewshed impacts. If not provided, all viewsheds are equally weighted with a weight of 1." msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:97 +#: src/natcap/invest/scenic_quality/scenic_quality.py:96 msgid "Viewpoint height, the elevation above the ground of each feature. If this field is not provided, defaults to 0." msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:102 +#: src/natcap/invest/scenic_quality/scenic_quality.py:101 msgid "Map of locations of objects that negatively affect scenic quality. This must have the same projection as the DEM." msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:112 +#: src/natcap/invest/scenic_quality/scenic_quality.py:111 msgid "refractivity coefficient" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:114 +#: src/natcap/invest/scenic_quality/scenic_quality.py:113 msgid "The refractivity coefficient corrects for the curvature of the earth and refraction of visible light in air." msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:125 +#: src/natcap/invest/scenic_quality/scenic_quality.py:124 msgid "Valuation function" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:129 +#: src/natcap/invest/scenic_quality/scenic_quality.py:128 msgid "linear: a + bx" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:130 +#: src/natcap/invest/scenic_quality/scenic_quality.py:129 msgid "logarithmic: a + b log(x+1)" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:132 +#: src/natcap/invest/scenic_quality/scenic_quality.py:131 msgid "exponential: a * e^(-bx)" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:134 +#: src/natcap/invest/scenic_quality/scenic_quality.py:133 msgid "Valuation function used to calculate the visual impact of each feature, given distance from the feature 'x' and parameters 'a' and 'b'." msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:140 +#: src/natcap/invest/scenic_quality/scenic_quality.py:139 msgid "coefficient a" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:144 +#: src/natcap/invest/scenic_quality/scenic_quality.py:143 msgid "First coefficient ('a') used by the valuation function" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:147 +#: src/natcap/invest/scenic_quality/scenic_quality.py:146 msgid "coefficient b" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:151 +#: src/natcap/invest/scenic_quality/scenic_quality.py:150 msgid "Second coefficient ('b') used by the valuation function" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:154 +#: src/natcap/invest/scenic_quality/scenic_quality.py:153 msgid "maximum valuation radius" msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:159 +#: src/natcap/invest/scenic_quality/scenic_quality.py:158 msgid "Valuation will only be computed for cells that fall within this radius of a feature impacting scenic quality." msgstr "" -#: src/natcap/invest/sdr/sdr.py:53 +#: src/natcap/invest/scenic_quality/scenic_quality.py:168 +msgid "Map of visual quality classified into quartiles." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:173 +msgid "This raster layer contains the weighted sum of all visibility rasters. If no weight column is provided in the structures point vector, this raster will represent a count of the number of structure points that are visible from each pixel." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:177 +msgid "This raster layer contains the weighted sum of the valuation rasters created for each point." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:186 +msgid "This vector is the AOI, reprojected to the DEM’s spatial reference and projection." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:191 +msgid "This raster layer is a version of the DEM that has been clipped and masked to the AOI and tiled. This is the DEM file that is used for the viewshed analysis." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:195 +msgid "Copy of the structures vector, clipped to the AOI extent." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:201 +msgid "Copy of the structures vector, reprojected to the DEM’s spatial reference and projection." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:206 +msgid "The calculated value of the viewshed amenity/disamenity given the distances of pixels from the structure's viewpoint, the weight of the viewpoint, the valuation function, and the a and b coefficients. The viewshed’s value is only evaluated for visible pixels." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:210 +msgid "Map of visibility for a given structure's viewpoint. This raster has pixel values of 0 (not visible), 1 (visible), or nodata (where the DEM is nodata)." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:54 msgid "Map of rainfall erosivity, reflecting the intensity and duration of rainfall in the area of interest." msgstr "" -#: src/natcap/invest/sdr/sdr.py:56 +#: src/natcap/invest/sdr/sdr.py:57 msgid "erosivity" msgstr "" -#: src/natcap/invest/sdr/sdr.py:64 +#: src/natcap/invest/sdr/sdr.py:65 msgid "Map of soil erodibility, the susceptibility of soil particles to detachment and transport by rainfall and runoff." msgstr "" -#: src/natcap/invest/sdr/sdr.py:68 +#: src/natcap/invest/sdr/sdr.py:69 msgid "soil erodibility" msgstr "" -#: src/natcap/invest/sdr/sdr.py:82 +#: src/natcap/invest/sdr/sdr.py:83 msgid "Map of the boundaries of the watershed(s) over which to aggregate results. Each watershed should contribute to a point of interest where water quality will be analyzed." msgstr "" -#: src/natcap/invest/sdr/sdr.py:86 +#: src/natcap/invest/sdr/sdr.py:87 msgid "Watersheds" msgstr "" -#: src/natcap/invest/sdr/sdr.py:94 +#: src/natcap/invest/sdr/sdr.py:96 msgid "Cover-management factor for the USLE" msgstr "" -#: src/natcap/invest/sdr/sdr.py:97 +#: src/natcap/invest/sdr/sdr.py:99 msgid "Support practice factor for the USLE" msgstr "" -#: src/natcap/invest/sdr/sdr.py:99 +#: src/natcap/invest/sdr/sdr.py:101 msgid "A table mapping each LULC code to biophysical properties of that LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "" -#: src/natcap/invest/sdr/sdr.py:109 +#: src/natcap/invest/sdr/sdr.py:111 msgid "Borselli k parameter." msgstr "" -#: src/natcap/invest/sdr/sdr.py:114 +#: src/natcap/invest/sdr/sdr.py:116 msgid "The maximum SDR value that a pixel can have." msgstr "" -#: src/natcap/invest/sdr/sdr.py:115 +#: src/natcap/invest/sdr/sdr.py:117 msgid "maximum SDR value" msgstr "" -#: src/natcap/invest/sdr/sdr.py:120 +#: src/natcap/invest/sdr/sdr.py:122 msgid "Borselli IC0 parameter." msgstr "" -#: src/natcap/invest/sdr/sdr.py:121 +#: src/natcap/invest/sdr/sdr.py:123 msgid "Borselli IC0 parameter" msgstr "" -#: src/natcap/invest/sdr/sdr.py:127 +#: src/natcap/invest/sdr/sdr.py:129 msgid "The maximum allowed value of the slope length parameter (L) in the LS factor." msgstr "" -#: src/natcap/invest/sdr/sdr.py:130 +#: src/natcap/invest/sdr/sdr.py:132 msgid "maximum l value" msgstr "" -#: src/natcap/invest/sdr/sdr.py:136 +#: src/natcap/invest/sdr/sdr.py:138 msgid "Map of locations of artificial drainages that drain to the watershed. Pixels with 1 are drainages and are treated like streams. Pixels with 0 are not drainages." msgstr "" -#: src/natcap/invest/sdr/sdr.py:140 +#: src/natcap/invest/sdr/sdr.py:142 msgid "drainages" msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:55 +#: src/natcap/invest/sdr/sdr.py:229 +msgid "CP factor derived by mapping usle_c and usle_p from the biophysical table to the LULC raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:235 +msgid "Downslope factor of the index of connectivity (Eq. (74))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:240 +msgid "Upslope factor of the index of connectivity (Eq. (73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:245 +msgid "Sediment downslope deposition, the amount of sediment from a given pixel that does not reach a stream (Eq. (78))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:254 +msgid "Map of sediment flux for sediment that does not reach the stream (Eq. (81))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:265 +msgid "Index of connectivity (Eq. (70))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:272 +msgid "LS factor for USLE (Eq. (69))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:280 +msgid "Flow accumulation weighted by the thresholded slope. Used in calculating s_bar." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:289 +msgid "Mean thresholded slope gradient of the upslope contributing area (in eq. (73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:298 +msgid "Sediment delivery ratio (Eq. (75))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:303 +msgid "Percent slope, thresholded to be no less than 0.005 and no greater than 1 (eq. (71)). 1 is equivalent to a 45 degree slope." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:310 +msgid "Flow accumulation weighted by the thresholded cover-management factor. Used in calculating w_bar." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:319 +msgid "Mean thresholded cover-management factor for upslope contributing area (in eq. (73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:325 +msgid "Cover-management factor derived by mapping usle_c from the biophysical table to the LULC raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:331 +msgid "Cover-management factor thresholded to be no less than 0.001 (eq. (72))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:337 +msgid "Average aspect weighted by flow direction (in eq. (69))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:342 +msgid "Map of which pixels drain to a stream. A value of 1 means that at least some of the runoff from that pixel drains to a stream in stream.tif. A value of 0 means that it does not drain at all to any stream in stream.tif." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:351 +msgid "Inverse of the thresholded cover-management factor times the thresholded slope (in eq. (74))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:357 +msgid "Copy of the input DEM, clipped to the extent of the other raster inputs." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:366 +msgid "Copy of the input drainage map, clipped to the extent of the other raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:373 +msgid "Copy of the input erodibility map, clipped to the extent of the other raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:383 +msgid "Copy of the input erosivity map, clipped to the extent of the other raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:393 +msgid "Copy of the input Land Use Land Cover map, clipped to the extent of the other raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:400 +msgid "A raster aligned to the DEM and clipped to the extent of the other raster inputs. Pixel values indicate where a nodata value exists in the stack of aligned rasters (pixel value of 0), or if all values in the stack of rasters at this pixel location are valid." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:410 +msgid "A copy of the aligned DEM, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:418 +msgid "A copy of the aligned drainage map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:425 +msgid "A copy of the aligned erodibility map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:435 +msgid "A copy of the aligned erosivity map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:444 +msgid "A copy of the aligned Land Use Land Cover map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:53 msgid "Twelve files, one for each month. File names must end with the month number (1-12). For example, the filenames 'et0_1.tif' 'evapotranspiration1.tif' are both valid for the month of January." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:64 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:62 msgid "Directory containing maps of reference evapotranspiration for each month. Only .tif files should be in this folder (no .tfw, .xml, etc files)." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:68 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:66 msgid "ET0 directory" msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:76 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:74 msgid "Twelve files, one for each month. File names must end with the month number (1-12). For example, the filenames 'precip_1.tif' and 'precip1.tif' are both valid names for the month of January." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:84 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:82 msgid "Directory containing maps of monthly precipitation for each month. Only .tif files should be in this folder (no .tfw, .xml, etc files)." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:88 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:86 msgid "precipitation directory" msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:97 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:95 msgid "All values in this raster MUST have corresponding entries in the Biophysical Table." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:117 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:116 msgid "Curve number values for each combination of soil group and LULC class. Replace [SOIL_GROUP] with each soil group code A, B, C, D so that there is one column for each soil group. Curve number values must be greater than 0." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:127 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:126 msgid "Crop/vegetation coefficient (Kc) values for this LULC class in each month. Replace [MONTH] with the numbers 1 to 12 so that there is one column for each month." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:134 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:133 msgid "A table mapping each LULC code to biophysical properties of the corresponding LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "" @@ -3062,51 +3720,163 @@ msgstr "" msgid "climate zones (advanced)" msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:220 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:221 msgid "Climate zone ID numbers, corresponding to the values in the Climate Zones map." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:226 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:227 msgid "The number of rain events that occur in each month in this climate zone. Replace [MONTH] with the month abbreviations: jan, feb, mar, apr, may, jun, jul, aug, sep, oct, nov, dec, so that there is a column for each month." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:234 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:235 msgid "Table of monthly precipitation events for each climate zone. Required if User-Defined Climate Zones is selected." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:237 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:238 msgid "climate zone table" msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:244 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:245 msgid "Map of climate zones. All values in this raster must have corresponding entries in the Climate Zone Table." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:247 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:248 msgid "climate zone map" msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:251 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:252 msgid "Use montly alpha values instead of a single value for the whole year." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:254 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:255 msgid "use monthly alpha table (advanced)" msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:262 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:264 msgid "Values are the numbers 1-12 corresponding to each month." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:269 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:271 msgid "The alpha value for that month." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:273 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:275 msgid "Table of alpha values for each month. Required if Use Monthly Alpha Table is selected." msgstr "" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:276 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:278 msgid "monthly alpha table" msgstr "" +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:283 +msgid "Map of baseflow values, the contribution of a pixel to slow release flow (which is not evapotranspired before it reaches the stream)." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:293 +msgid "Map of B_sum values, the flow through a pixel, contributed by all upslope pixels, that is not evapotranspirated before it reaches the stream." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:303 +msgid "Map of curve number values." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:310 +msgid "Map of available local recharge" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:317 +msgid "Map of local recharge values" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:324 +msgid "Map of total available water, contributed by all upslope pixels, that is available for evapotranspiration by this pixel." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:333 +msgid "Map of cumulative upstream recharge: the flow through a pixel, contributed by all upslope pixels, that is available for evapotranspiration to downslope pixels." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:343 +msgid "Map of quickflow" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:350 +msgid "The total precipitation across all months on this pixel." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:357 +msgid "Map of the values of recharge (contribution, positive or negative), to the total recharge." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:366 +msgid "Table of biophysical values for each watershed" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:370 +msgid "Mean local recharge value within the watershed" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:376 +msgid "Total recharge contribution, (positive or negative) within the watershed." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:388 +msgid "Map of actual evapotranspiration" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:395 +msgid "Map of multiple flow direction. Values are encoded in a binary format and should not be used directly." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:401 +msgid "Maps of monthly quickflow (1 = January… 12 = December)" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:409 +msgid "Stream network map generated from the input DEM and Threshold Flow Accumulation. Values of 1 represent streams, values of 0 are non-stream pixels." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:418 +msgid "Map of the S_i factor derived from CN" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:422 +msgid "Copy of LULC input, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:427 +msgid "Copy of DEM input, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:432 +msgid "Pit filled DEM" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:436 +msgid "Copy of soil groups input, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:443 +msgid "Monthly precipitation rasters, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:447 +msgid "Map of monthly rain events" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:452 +msgid "Monthly ET0 rasters, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:456 +msgid "Map of monthly KC values" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:460 +msgid "Copy of user-defined local recharge input, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:465 +msgid "Copy of user-defined climate zones raster, aligned and clipped to match the other spatial inputs" +msgstr "" + From 8c545b2a62d47e9c1aba8ab8bc8d6e9a07fcba61 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 25 Mar 2024 13:55:54 -0700 Subject: [PATCH 05/90] extract message catalog template and update zh catalog from it --- .../locales/zh/LC_MESSAGES/messages.po | 4122 ++++++++++++----- 1 file changed, 3020 insertions(+), 1102 deletions(-) diff --git a/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po b/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po index 6bbf865129..3af5c611b4 100644 --- a/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po +++ b/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po @@ -7,954 +7,1166 @@ msgid "" msgstr "" "Project-Id-Version: InVEST 3.12\n" "Report-Msgid-Bugs-To: jdouglass@stanford.edu\n" -"POT-Creation-Date: 2023-03-03 12:40-0800\n" +"POT-Creation-Date: 2024-03-25 13:25-0700\n" "PO-Revision-Date: 2023-03-16 14:02-0700\n" "Last-Translator: \n" -"Language-Team: zh \n" "Language: zh\n" +"Language-Team: zh \n" +"Plural-Forms: nplurals=1; plural=0;\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Plural-Forms: nplurals=1; plural=0;\n" -"Generated-By: Babel 2.10.3\n" -"X-Generator: Poedit 3.2.2\n" +"Generated-By: Babel 2.14.0\n" + +#: src/natcap/invest/annual_water_yield.py:92 +#: src/natcap/invest/annual_water_yield.py:186 +msgid "Unique identifier for each subwatershed." +msgstr "每个流域的唯一标识符。" -#: src/natcap/invest/annual_water_yield.py:43 -#: src/natcap/invest/forest_carbon_edge_effect.py:113 -#: src/natcap/invest/sdr/sdr.py:73 -msgid "All values in this raster must have corresponding entries in the Biophysical Table." +#: src/natcap/invest/annual_water_yield.py:101 +#: src/natcap/invest/annual_water_yield.py:170 +msgid "Unique identifier for each watershed." +msgstr "每个流域的唯一标识符。" + +#: src/natcap/invest/annual_water_yield.py:129 +#: src/natcap/invest/forest_carbon_edge_effect.py:115 +#: src/natcap/invest/sdr/sdr.py:74 +msgid "" +"All values in this raster must have corresponding entries in the " +"Biophysical Table." msgstr "该栅格中的所有数值必须在生物物理表中有相应的条目。" -#: src/natcap/invest/annual_water_yield.py:54 -msgid "Map of root restricting layer depth, the soil depth at which root penetration is strongly inhibited because of physical or chemical characteristics." +#: src/natcap/invest/annual_water_yield.py:140 +msgid "" +"Map of root restricting layer depth, the soil depth at which root " +"penetration is strongly inhibited because of physical or chemical " +"characteristics." msgstr "根系限制层深度图,由于物理或化学特性,根系渗透受到强烈抑制的土壤深度。" -#: src/natcap/invest/annual_water_yield.py:58 +#: src/natcap/invest/annual_water_yield.py:144 msgid "root restricting layer depth" msgstr "根系限制层的深度" -#: src/natcap/invest/annual_water_yield.py:68 -msgid "Map of plant available water content, the fraction of water that can be stored in the soil profile that is available to plants." +#: src/natcap/invest/annual_water_yield.py:154 +msgid "" +"Map of plant available water content, the fraction of water that can be " +"stored in the soil profile that is available to plants." msgstr "植物可用水分含量图,即可储存在土壤剖面中的、可供植物使用的那部分水。" -#: src/natcap/invest/annual_water_yield.py:72 +#: src/natcap/invest/annual_water_yield.py:158 msgid "plant available water content" msgstr "植物可用水分含量" -#: src/natcap/invest/annual_water_yield.py:84 -msgid "Unique identifier for each watershed." -msgstr "每个流域的唯一标识符。" - -#: src/natcap/invest/annual_water_yield.py:88 -msgid "Map of watershed boundaries, such that each watershed drains to a point of interest where hydropower production will be analyzed." +#: src/natcap/invest/annual_water_yield.py:174 +msgid "" +"Map of watershed boundaries, such that each watershed drains to a point " +"of interest where hydropower production will be analyzed." msgstr "流域边界图,以便每个流域排水到一个兴趣点,在那里水电生产将被分析。" -#: src/natcap/invest/annual_water_yield.py:92 src/natcap/invest/ndr/ndr.py:72 +#: src/natcap/invest/annual_water_yield.py:178 src/natcap/invest/ndr/ndr.py:73 msgid "watersheds" msgstr "流域" -#: src/natcap/invest/annual_water_yield.py:100 -msgid "Unique identifier for each subwatershed." -msgstr "每个流域的唯一标识符。" - -#: src/natcap/invest/annual_water_yield.py:105 -msgid "Map of subwatershed boundaries within each watershed in the Watersheds map." +#: src/natcap/invest/annual_water_yield.py:191 +msgid "" +"Map of subwatershed boundaries within each watershed in the Watersheds " +"map." msgstr "流域地图中每个流域内的小流域边界图。" -#: src/natcap/invest/annual_water_yield.py:108 +#: src/natcap/invest/annual_water_yield.py:194 msgid "sub-watersheds" msgstr "流域" -#: src/natcap/invest/annual_water_yield.py:116 -msgid "Code indicating whether the the LULC class is vegetated for the purpose of AET. Enter 1 for all vegetated classes except wetlands, and 0 for all other classes, including wetlands, urban areas, water bodies, etc." +#: src/natcap/invest/annual_water_yield.py:202 +msgid "" +"Code indicating whether the the LULC class is vegetated for the purpose " +"of AET. Enter 1 for all vegetated classes except wetlands, and 0 for all " +"other classes, including wetlands, urban areas, water bodies, etc." msgstr "表示LULC等级是否为植被的代码,用于AET的目的。除湿地外,所有植被等级均为1,所有其他等级均为0,包括湿地、城市区域、水体等。" -#: src/natcap/invest/annual_water_yield.py:126 -msgid "Maximum root depth for plants in this LULC class. Only used for classes with a 'lulc_veg' value of 1." +#: src/natcap/invest/annual_water_yield.py:212 +msgid "" +"Maximum root depth for plants in this LULC class. Only used for classes " +"with a 'lulc_veg' value of 1." msgstr "该LULC的植物最大根系深度。只用于'lulc_veg'值为1的类。" -#: src/natcap/invest/annual_water_yield.py:133 -#: src/natcap/invest/urban_cooling_model.py:63 +#: src/natcap/invest/annual_water_yield.py:219 +#: src/natcap/invest/urban_cooling_model.py:65 msgid "Crop coefficient for this LULC class." msgstr "LULC的作物系数。" -#: src/natcap/invest/annual_water_yield.py:135 -msgid "Table of biophysical parameters for each LULC class. All values in the LULC raster must have corresponding entries in this table." +#: src/natcap/invest/annual_water_yield.py:222 +msgid "" +"Table of biophysical parameters for each LULC class. All values in the " +"LULC raster must have corresponding entries in this table." msgstr "LULC生物物理参数表。LULC栅格中的所有值都必须在该表中有相应的条目。" -#: src/natcap/invest/annual_water_yield.py:139 -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:205 -#: src/natcap/invest/forest_carbon_edge_effect.py:109 -#: src/natcap/invest/ndr/ndr.py:118 src/natcap/invest/pollination.py:116 -#: src/natcap/invest/sdr/sdr.py:103 -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:138 -#: src/natcap/invest/urban_cooling_model.py:56 -#: src/natcap/invest/urban_flood_risk_mitigation.py:76 +#: src/natcap/invest/annual_water_yield.py:226 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:208 +#: src/natcap/invest/forest_carbon_edge_effect.py:111 +#: src/natcap/invest/ndr/ndr.py:120 src/natcap/invest/pollination.py:118 +#: src/natcap/invest/sdr/sdr.py:105 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:137 +#: src/natcap/invest/urban_cooling_model.py:57 +#: src/natcap/invest/urban_flood_risk_mitigation.py:77 msgid "biophysical table" msgstr "生物物理表" -#: src/natcap/invest/annual_water_yield.py:145 -msgid "The seasonality factor, representing hydrogeological characterisitics and the seasonal distribution of precipitation. Values typically range from 1 - 30." +#: src/natcap/invest/annual_water_yield.py:232 +msgid "" +"The seasonality factor, representing hydrogeological characterisitics and" +" the seasonal distribution of precipitation. Values typically range from " +"1 - 30." msgstr "季节性因子,代表水文地质特征和降水的季节分布。值的范围通常为1 - 30。" -#: src/natcap/invest/annual_water_yield.py:149 +#: src/natcap/invest/annual_water_yield.py:236 msgid "z parameter" msgstr "z参数" -#: src/natcap/invest/annual_water_yield.py:155 +#: src/natcap/invest/annual_water_yield.py:242 msgid "LULC code corresponding to the LULC raster" msgstr "与LULC栅格中的值相对应的LULC代码" -#: src/natcap/invest/annual_water_yield.py:159 +#: src/natcap/invest/annual_water_yield.py:246 msgid "Average consumptive water use in this LULC class." msgstr "LULC的平均耗水量。" -#: src/natcap/invest/annual_water_yield.py:166 -msgid "A table of water demand for each LULC class. Each LULC code in the LULC raster must have a corresponding row in this table." +#: src/natcap/invest/annual_water_yield.py:254 +msgid "" +"A table of water demand for each LULC class. Each LULC code in the LULC " +"raster must have a corresponding row in this table." msgstr "每个LULC的水需求表。LULC栅格中的每个LULC代码必须在该表中有相应的条目。" -#: src/natcap/invest/annual_water_yield.py:170 +#: src/natcap/invest/annual_water_yield.py:258 msgid "water demand table" msgstr "水需求表" -#: src/natcap/invest/annual_water_yield.py:177 -msgid "Unique identifier for the hydropower station. This must match the 'ws_id' value for the corresponding watershed in the Watersheds vector. Each watershed in the Watersheds vector must have its 'ws_id' entered in this column." +#: src/natcap/invest/annual_water_yield.py:265 +msgid "" +"Unique identifier for the hydropower station. This must match the 'ws_id'" +" value for the corresponding watershed in the Watersheds vector. Each " +"watershed in the Watersheds vector must have its 'ws_id' entered in this " +"column." msgstr "水电站的唯一标识符。这必须匹配流域向量中相应流域的'ws_id'值。流域向量中的每个流域必须在这一列中输入它的“ws_id”。" -#: src/natcap/invest/annual_water_yield.py:186 -msgid "Turbine efficiency, the proportion of potential energy captured and converted to electricity by the turbine." +#: src/natcap/invest/annual_water_yield.py:274 +msgid "" +"Turbine efficiency, the proportion of potential energy captured and " +"converted to electricity by the turbine." msgstr "涡轮机效率,即涡轮机捕获并转化为电能的比例。" -#: src/natcap/invest/annual_water_yield.py:193 +#: src/natcap/invest/annual_water_yield.py:281 msgid "The proportion of inflow water volume that is used to generate energy." msgstr "用于发电的流入水量占总水量的比例。" -#: src/natcap/invest/annual_water_yield.py:200 -msgid "The head, measured as the average annual effective height of water behind each dam at the turbine intake." +#: src/natcap/invest/annual_water_yield.py:288 +msgid "" +"The head, measured as the average annual effective height of water behind" +" each dam at the turbine intake." msgstr "水头,是指在水轮机进水口处每个大坝后的平均年有效水位。" -#: src/natcap/invest/annual_water_yield.py:208 -msgid "The price of power produced by the station. Must be in the same currency used in the 'cost' column." +#: src/natcap/invest/annual_water_yield.py:296 +msgid "" +"The price of power produced by the station. Must be in the same currency " +"used in the 'cost' column." msgstr "发电站发电的价格。必须在“成本”栏中使用相同的货币。" -#: src/natcap/invest/annual_water_yield.py:215 -msgid "Annual maintenance and operations cost of running the hydropower station. Must be in the same currency used in the 'kw_price' column." +#: src/natcap/invest/annual_water_yield.py:303 +msgid "" +"Annual maintenance and operations cost of running the hydropower station." +" Must be in the same currency used in the 'kw_price' column." msgstr "水电站运行年度维护运行费用。必须与“kw_price”列中使用的货币相同。" -#: src/natcap/invest/annual_water_yield.py:223 -msgid "Number of years over which to value the hydropower station. This is either the station's expected lifespan or the duration of the land use scenario of interest." +#: src/natcap/invest/annual_water_yield.py:311 +msgid "" +"Number of years over which to value the hydropower station. This is " +"either the station's expected lifespan or the duration of the land use " +"scenario of interest." msgstr "为水电站估价的年数。这要么是空间站的预期寿命,要么是有关土地使用情况的持续时间。" -#: src/natcap/invest/annual_water_yield.py:231 +#: src/natcap/invest/annual_water_yield.py:319 msgid "The annual discount rate, applied for each year in the time span." msgstr "年度贴现率,适用于时间跨度内的每一年。" -#: src/natcap/invest/annual_water_yield.py:237 -msgid "A table mapping each watershed to the associated valuation parameters for its hydropower station." +#: src/natcap/invest/annual_water_yield.py:326 +msgid "" +"A table mapping each watershed to the associated valuation parameters for" +" its hydropower station." msgstr "将每个流域映射到其水电站的相关估值参数的表格。" -#: src/natcap/invest/annual_water_yield.py:240 +#: src/natcap/invest/annual_water_yield.py:329 msgid "hydropower valuation table" msgstr "水电估价表" -#: src/natcap/invest/carbon.py:38 -msgid "A map of LULC for the current scenario. All values in this raster must have corresponding entries in the Carbon Pools table." +#: src/natcap/invest/carbon.py:59 +msgid "" +"A map of LULC for the current scenario. All values in this raster must " +"have corresponding entries in the Carbon Pools table." msgstr "当前场景的LULC。该栅格中的所有值都必须在碳库表中有相应的条目。" -#: src/natcap/invest/carbon.py:42 +#: src/natcap/invest/carbon.py:63 msgid "current LULC" msgstr "现状LULC" -#: src/natcap/invest/carbon.py:47 -msgid "Run sequestration analysis. This requires inputs of LULC maps for both current and future scenarios. Required if REDD scenario analysis or run valuation model is selected." +#: src/natcap/invest/carbon.py:68 +msgid "" +"Run sequestration analysis. This requires inputs of LULC maps for both " +"current and future scenarios. Required if REDD scenario analysis or run " +"valuation model is selected." msgstr "运行固碳分析。这需要输入当前和未来情景下的LULC地图。如果选择REDD情景分析或运行估值模型,则需要。" -#: src/natcap/invest/carbon.py:52 +#: src/natcap/invest/carbon.py:73 msgid "calculate sequestration" msgstr "计算封存" -#: src/natcap/invest/carbon.py:59 -msgid "A map of LULC for the future scenario. If run valuation model is selected, this should be the reference, or baseline, future scenario against which to compare the REDD policy scenario. All values in this raster must have corresponding entries in the Carbon Pools table. Required if Calculate Sequestration is selected." +#: src/natcap/invest/carbon.py:80 +msgid "" +"A map of LULC for the future scenario. If run valuation model is " +"selected, this should be the reference, or baseline, future scenario " +"against which to compare the REDD policy scenario. All values in this " +"raster must have corresponding entries in the Carbon Pools table. " +"Required if Calculate Sequestration is selected." msgstr "未来情景下的LULC地图。如果选择运行评估模型,这应该是参考或基线的未来情景,用来比较REDD政策情景。该栅格中的所有数值必须在碳库表中有相应的条目。如果选择计算固存量,则需要。" -#: src/natcap/invest/carbon.py:67 +#: src/natcap/invest/carbon.py:88 msgid "future LULC" msgstr "未来的LULC" -#: src/natcap/invest/carbon.py:72 -msgid "Run REDD scenario analysis. This requires three LULC maps: one for the current scenario, one for the future baseline scenario, and one for the future REDD policy scenario." +#: src/natcap/invest/carbon.py:93 +msgid "" +"Run REDD scenario analysis. This requires three LULC maps: one for the " +"current scenario, one for the future baseline scenario, and one for the " +"future REDD policy scenario." msgstr "运行REDD情景分析。这需要三张LULC地图:一张用于当前情景,一张用于未来基线情景,一张用于未来REDD政策情景。" -#: src/natcap/invest/carbon.py:77 +#: src/natcap/invest/carbon.py:98 msgid "REDD scenario analysis" msgstr "REDD情景分析" -#: src/natcap/invest/carbon.py:84 -msgid "A map of LULC for the REDD policy scenario. All values in this raster must have corresponding entries in the Carbon Pools table. Required if REDD Scenario Analysis is selected." +#: src/natcap/invest/carbon.py:105 +msgid "" +"A map of LULC for the REDD policy scenario. All values in this raster " +"must have corresponding entries in the Carbon Pools table. Required if " +"REDD Scenario Analysis is selected." msgstr "REDD政策情景下的LULC地图。该栅格中的所有值必须在碳库表中有相应的条目。如果选择REDD情景分析,则需要。" -#: src/natcap/invest/carbon.py:89 +#: src/natcap/invest/carbon.py:110 msgid "REDD LULC" msgstr "REDD LULC" -#: src/natcap/invest/carbon.py:98 +#: src/natcap/invest/carbon.py:119 msgid "Carbon density of aboveground biomass." msgstr "地上生物量的碳密度。" -#: src/natcap/invest/carbon.py:102 +#: src/natcap/invest/carbon.py:123 msgid "Carbon density of belowground biomass." msgstr "地下生物量的碳密度。" -#: src/natcap/invest/carbon.py:106 +#: src/natcap/invest/carbon.py:127 msgid "Carbon density of soil." msgstr "土壤的碳密度。" -#: src/natcap/invest/carbon.py:110 +#: src/natcap/invest/carbon.py:131 msgid "Carbon density of dead matter." msgstr "枯木的碳密度。" -#: src/natcap/invest/carbon.py:112 +#: src/natcap/invest/carbon.py:134 msgid "A table that maps each LULC code to carbon pool data for that LULC type." msgstr "将每个LULC代码映射到该LULC类型的碳库数据的表格。" -#: src/natcap/invest/carbon.py:115 +#: src/natcap/invest/carbon.py:137 msgid "carbon pools" msgstr "碳库" -#: src/natcap/invest/carbon.py:122 -msgid "The calendar year of the current scenario depicted in the current LULC map. Required if Run Valuation model is selected." +#: src/natcap/invest/carbon.py:144 +msgid "" +"The calendar year of the current scenario depicted in the current LULC " +"map. Required if Run Valuation model is selected." msgstr "当前LULC地图中描述的当前情景年。如果选择运行评估模型,则需要。" -#: src/natcap/invest/carbon.py:125 +#: src/natcap/invest/carbon.py:147 msgid "current LULC year" msgstr "现状LULC" -#: src/natcap/invest/carbon.py:132 -msgid "The calendar year of the future scenario depicted in the future LULC map. Required if Run Valuation model is selected." +#: src/natcap/invest/carbon.py:154 +msgid "" +"The calendar year of the future scenario depicted in the future LULC map." +" Required if Run Valuation model is selected." msgstr "未来LULC地图中描述的未来情景年。如果选择运行评估模式,则需要。" -#: src/natcap/invest/carbon.py:140 -msgid "Calculate net present value for the future scenario, and the REDD scenario if provided, and report it in the final HTML document." +#: src/natcap/invest/carbon.py:162 +msgid "" +"Calculate net present value for the future scenario, and the REDD " +"scenario if provided, and report it in the final HTML document." msgstr "计算未来方案的净现值,如果提供REDD方案,则计算REDD方案,并在最后的HTML文件中报告。" -#: src/natcap/invest/carbon.py:144 +#: src/natcap/invest/carbon.py:166 msgid "run valuation model" msgstr "运行估价模型" -#: src/natcap/invest/carbon.py:150 +#: src/natcap/invest/carbon.py:172 msgid "The present value of carbon. Required if Run Valuation model is selected." msgstr "碳的价格。如果选择运行评估模型,则需要。" -#: src/natcap/invest/carbon.py:153 +#: src/natcap/invest/carbon.py:175 msgid "price of carbon" msgstr "碳的价格" -#: src/natcap/invest/carbon.py:158 -msgid "The annual market discount rate in the price of carbon, which reflects society's preference for immediate benefits over future benefits. Required if Run Valuation model is selected." +#: src/natcap/invest/carbon.py:180 +msgid "" +"The annual market discount rate in the price of carbon, which reflects " +"society's preference for immediate benefits over future benefits. " +"Required if Run Valuation model is selected." msgstr "碳价格中的年度市场贴现率,反映了社会对眼前利益比未来利益的偏好。如果选择运行评估模式则需要。" -#: src/natcap/invest/carbon.py:163 +#: src/natcap/invest/carbon.py:185 msgid "annual market discount rate" msgstr "年度市场贴现率" -#: src/natcap/invest/carbon.py:168 -msgid "The relative annual increase of the price of carbon. Required if Run Valuation model is selected." +#: src/natcap/invest/carbon.py:190 +msgid "" +"The relative annual increase of the price of carbon. Required if Run " +"Valuation model is selected." msgstr "碳价格的相对年度增长。如果选择运行评估模型,则需要。" -#: src/natcap/invest/carbon.py:171 +#: src/natcap/invest/carbon.py:193 msgid "annual price change" msgstr "年度价格变化" -#: src/natcap/invest/cli.py:55 +#: src/natcap/invest/cli.py:56 msgid "Available models:" msgstr "可用的模型:" -#: src/natcap/invest/coastal_vulnerability.py:33 +#: src/natcap/invest/coastal_vulnerability.py:36 msgid "Must be a polyline vector" msgstr "必须是一个多线矢量" -#: src/natcap/invest/coastal_vulnerability.py:34 +#: src/natcap/invest/coastal_vulnerability.py:37 msgid "Must be a point or multipoint geometry." msgstr "必须是一个点或多点的几何体。" -#: src/natcap/invest/coastal_vulnerability.py:60 -msgid "Map of the region over which to run the model." -msgstr "运行模型的区域地图。" - -#: src/natcap/invest/coastal_vulnerability.py:66 -msgid "Interval at which to space shore points along the coastline." -msgstr "沿着海岸线的海岸点的间隔。" - -#: src/natcap/invest/coastal_vulnerability.py:68 -msgid "model resolution" -msgstr "模型分辨率" - -#: src/natcap/invest/coastal_vulnerability.py:74 -msgid "Map of all landmasses in and around the region of interest. It is not recommended to clip this landmass to the AOI polygon because some functions in the model require searching for landmasses around shore points up to the distance defined in Maximum Fetch Distance, which likely extends beyond the AOI polygon." -msgstr "兴趣区域内及其周围的所有地块的地图。不建议将该地块夹在 AOI 多边形中,因为模型中的一些功能需要搜索海岸点周围的地块,直到最大取样距离中定义的距离,这很可能超出了 AOI 多边形。" - -#: src/natcap/invest/coastal_vulnerability.py:81 -msgid "landmasses" -msgstr "陆地" - -#: src/natcap/invest/coastal_vulnerability.py:88 +#: src/natcap/invest/coastal_vulnerability.py:93 #, python-format -msgid "Proportion of the highest 10% of wind speeds in the record of interest that blow in the direction of each sector." +msgid "" +"Proportion of the highest 10% of wind speeds in the record of interest " +"that blow in the direction of each sector." msgstr "在感兴趣的记录中,吹向各方向的最高10% of风速的比例。" -#: src/natcap/invest/coastal_vulnerability.py:95 +#: src/natcap/invest/coastal_vulnerability.py:100 #, python-format -msgid "Average of the highest 10% of wind speeds that blow in the direction of each sector." +msgid "" +"Average of the highest 10% of wind speeds that blow in the direction of " +"each sector." msgstr "吹向各方向的最高10% of风速的平均值。" -#: src/natcap/invest/coastal_vulnerability.py:100 +#: src/natcap/invest/coastal_vulnerability.py:105 #, python-format -msgid "Proportion of the highest 10% of wave power values on record that are in each sector." +msgid "" +"Proportion of the highest 10% of wave power values on record that are in " +"each sector." msgstr "每个区段的最高10% of波能的记录比例。" -#: src/natcap/invest/coastal_vulnerability.py:106 +#: src/natcap/invest/coastal_vulnerability.py:111 #, python-format -msgid "Average of the highest 10% of wave power values on record in the direction of each sector." +msgid "" +"Average of the highest 10% of wave power values on record in the " +"direction of each sector." msgstr "每个方向上记录的最高10% of波能的平均值。" -#: src/natcap/invest/coastal_vulnerability.py:111 +#: src/natcap/invest/coastal_vulnerability.py:116 #, python-format -msgid "Average of the highest 10% of wind speeds that are centered on each main sector direction X." +msgid "" +"Average of the highest 10% of wind speeds that are centered on each main " +"sector direction X." msgstr "以每个主要扇形方向X为中心的最高10% of风速的平均值。" -#: src/natcap/invest/coastal_vulnerability.py:116 -msgid "Map of gridded wind and wave data that represent storm conditions. This global dataset is provided with the InVEST sample data. There are 80 required columns; each of the 5 types is repeated for each sixteenth sector of the 360° compass: [0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For example: REI_PCT0, V10PCT_90." +#: src/natcap/invest/coastal_vulnerability.py:145 +msgid "Map of the region over which to run the model." +msgstr "运行模型的区域地图。" + +#: src/natcap/invest/coastal_vulnerability.py:151 +msgid "Interval at which to space shore points along the coastline." +msgstr "沿着海岸线的海岸点的间隔。" + +#: src/natcap/invest/coastal_vulnerability.py:153 +msgid "model resolution" +msgstr "模型分辨率" + +#: src/natcap/invest/coastal_vulnerability.py:159 +msgid "" +"Map of all landmasses in and around the region of interest. It is not " +"recommended to clip this landmass to the AOI polygon because some " +"functions in the model require searching for landmasses around shore " +"points up to the distance defined in Maximum Fetch Distance, which likely" +" extends beyond the AOI polygon." +msgstr "" +"兴趣区域内及其周围的所有地块的地图。不建议将该地块夹在 AOI " +"多边形中,因为模型中的一些功能需要搜索海岸点周围的地块,直到最大取样距离中定义的距离,这很可能超出了 AOI 多边形。" + +#: src/natcap/invest/coastal_vulnerability.py:166 +msgid "landmasses" +msgstr "陆地" + +#: src/natcap/invest/coastal_vulnerability.py:172 +msgid "" +"Map of gridded wind and wave data that represent storm conditions. This " +"global dataset is provided with the InVEST sample data. There are 80 " +"required columns; each of the 5 types is repeated for each sixteenth " +"sector of the 360° compass: " +"[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For example:" +" REI_PCT0, V10PCT_90." msgstr "代表风暴条件的风浪栅格数据图。这个全球数据集是与InVEST样本数据一起提供的。有80个所需的列;5种类型中的每一种都在360°罗盘的每十六个扇形区域内重复。[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337].比如说REI_PCT0,V10PCT_90。" -#: src/natcap/invest/coastal_vulnerability.py:124 +#: src/natcap/invest/coastal_vulnerability.py:180 msgid "WaveWatchIII" msgstr "波浪观察III" -#: src/natcap/invest/coastal_vulnerability.py:130 -msgid "Maximum distance in meters to extend rays from shore points. Points with rays equal to this distance accumulate ocean- driven wave exposure along those rays and local-wind-driven wave exposure along the shorter rays." +#: src/natcap/invest/coastal_vulnerability.py:186 +msgid "" +"Maximum distance in meters to extend rays from shore points. Points with " +"rays equal to this distance accumulate ocean- driven wave exposure along " +"those rays and local-wind-driven wave exposure along the shorter rays." msgstr "从海岸点延伸出的射线的最大距离(米)。射线等于这个距离的点,沿着这些射线积累海洋驱动的波浪暴露,沿着较短的射线积累局部风驱动的波浪暴露。" -#: src/natcap/invest/coastal_vulnerability.py:135 +#: src/natcap/invest/coastal_vulnerability.py:191 msgid "maximum fetch distance" msgstr "最大取水距离" -#: src/natcap/invest/coastal_vulnerability.py:143 -msgid "Map of bathymetry (ocean depth). Bathymetry values should be negative, and any positive values will be ignored. This should cover the area extending beyond the AOI to the maximum fetch distance." +#: src/natcap/invest/coastal_vulnerability.py:199 +msgid "" +"Map of bathymetry (ocean depth). Bathymetry values should be negative, " +"and any positive values will be ignored. This should cover the area " +"extending beyond the AOI to the maximum fetch distance." msgstr "水深测量(海洋深度)地图。水深值应该是负值,任何正值都将被忽略。这应涵盖AOI之外延伸到最大风速距离的区域。" -#: src/natcap/invest/coastal_vulnerability.py:149 +#: src/natcap/invest/coastal_vulnerability.py:205 msgid "Bathymetry" msgstr "测深学" -#: src/natcap/invest/coastal_vulnerability.py:155 -msgid "Map of the edges of the continental shelf or other locally relevant bathymetry contour." +#: src/natcap/invest/coastal_vulnerability.py:211 +msgid "" +"Map of the edges of the continental shelf or other locally relevant " +"bathymetry contour." msgstr "大陆边缘的地图或其他与当地相关的水深等值线。" -#: src/natcap/invest/coastal_vulnerability.py:158 +#: src/natcap/invest/coastal_vulnerability.py:214 msgid "continental shelf contour" msgstr "大陆架等高线" -#: src/natcap/invest/coastal_vulnerability.py:166 -msgid "Map of elevation above sea level on land. This should cover the area extending beyond the AOI by at least the elevation averaging radius. Elevation may be measured in any unit." +#: src/natcap/invest/coastal_vulnerability.py:222 +msgid "" +"Map of elevation above sea level on land. This should cover the area " +"extending beyond the AOI by at least the elevation averaging radius. " +"Elevation may be measured in any unit." msgstr "陆地上的海平面以上地图。该图应涵盖AOI以外的区域,至少是高程平均半径的范围。高程可以用任何单位来测量。" -#: src/natcap/invest/coastal_vulnerability.py:175 -msgid "A radius around each shore point within which to average the elevation values in the DEM raster." +#: src/natcap/invest/coastal_vulnerability.py:231 +msgid "" +"A radius around each shore point within which to average the elevation " +"values in the DEM raster." msgstr "每个海岸点的半径,在此范围内对DEM栅格中的高程值进行平均。" -#: src/natcap/invest/coastal_vulnerability.py:178 +#: src/natcap/invest/coastal_vulnerability.py:234 msgid "elevation averaging radius" msgstr "高程平均半径" -#: src/natcap/invest/coastal_vulnerability.py:185 +#: src/natcap/invest/coastal_vulnerability.py:241 msgid "Unique name for the habitat. No spaces allowed." msgstr "生境的独特名称。不允许有空格。" -#: src/natcap/invest/coastal_vulnerability.py:191 -msgid "Map of area(s) where the habitat is present. If raster, presence of the habitat can be represented by any value and absence of the habitat can be represented by 0 and nodata values." +#: src/natcap/invest/coastal_vulnerability.py:247 +msgid "" +"Map of area(s) where the habitat is present. If raster, presence of the " +"habitat can be represented by any value and absence of the habitat can be" +" represented by 0 and nodata values." msgstr "生境存在的区域地图。如果是栅格图,生境的存在可以用任何数值表示,生境的缺失可以用0和nodata值表示。" -#: src/natcap/invest/coastal_vulnerability.py:199 -msgid "very high protection" -msgstr "极高的保护" - -#: src/natcap/invest/coastal_vulnerability.py:200 -msgid "high protection" -msgstr "高度保护" - -#: src/natcap/invest/coastal_vulnerability.py:201 -msgid "moderate protection" -msgstr "中度保护" - -#: src/natcap/invest/coastal_vulnerability.py:202 -msgid "low protection" -msgstr "低保护" - -#: src/natcap/invest/coastal_vulnerability.py:203 -msgid "very low protection" -msgstr "极低保护" - -#: src/natcap/invest/coastal_vulnerability.py:205 -msgid "Relative amount of coastline protection this habitat provides." +#: src/natcap/invest/coastal_vulnerability.py:254 +#, fuzzy +msgid "" +"Relative amount of coastline protection this habitat provides, from 1 " +"(very high protection) to 5 (very low protection." msgstr "该生境提供的海岸线保护的相对数量。" -#: src/natcap/invest/coastal_vulnerability.py:213 -msgid "The distance beyond which this habitat will provide no protection to the coastline." +#: src/natcap/invest/coastal_vulnerability.py:263 +msgid "" +"The distance beyond which this habitat will provide no protection to the " +"coastline." msgstr "超过这个距离,这个生境就不能对海岸线提供保护。" -#: src/natcap/invest/coastal_vulnerability.py:218 +#: src/natcap/invest/coastal_vulnerability.py:269 msgid "Table that specifies spatial habitat data and parameters." msgstr "指定空间生境数据和参数的表格。" -#: src/natcap/invest/coastal_vulnerability.py:220 +#: src/natcap/invest/coastal_vulnerability.py:271 msgid "habitats table" msgstr "生境表" -#: src/natcap/invest/coastal_vulnerability.py:228 +#: src/natcap/invest/coastal_vulnerability.py:279 +#: src/natcap/invest/coastal_vulnerability.py:416 msgid "very low exposure" msgstr "极低暴露" -#: src/natcap/invest/coastal_vulnerability.py:229 +#: src/natcap/invest/coastal_vulnerability.py:280 +#: src/natcap/invest/coastal_vulnerability.py:417 msgid "low exposure" msgstr "低暴露" -#: src/natcap/invest/coastal_vulnerability.py:230 +#: src/natcap/invest/coastal_vulnerability.py:281 +#: src/natcap/invest/coastal_vulnerability.py:418 msgid "moderate exposure" msgstr "中度暴露" -#: src/natcap/invest/coastal_vulnerability.py:231 +#: src/natcap/invest/coastal_vulnerability.py:282 +#: src/natcap/invest/coastal_vulnerability.py:419 msgid "high exposure" msgstr "高暴露" -#: src/natcap/invest/coastal_vulnerability.py:232 +#: src/natcap/invest/coastal_vulnerability.py:283 +#: src/natcap/invest/coastal_vulnerability.py:420 msgid "very high exposure" msgstr "极高暴露" -#: src/natcap/invest/coastal_vulnerability.py:234 +#: src/natcap/invest/coastal_vulnerability.py:285 +#: src/natcap/invest/coastal_vulnerability.py:422 msgid "Relative exposure of the segment of coastline." msgstr "该段海岸线的相对暴露。" -#: src/natcap/invest/coastal_vulnerability.py:239 +#: src/natcap/invest/coastal_vulnerability.py:290 msgid "Map of relative exposure of each segment of coastline." msgstr "每段海岸线的相对曝露地图。" -#: src/natcap/invest/coastal_vulnerability.py:240 +#: src/natcap/invest/coastal_vulnerability.py:291 msgid "geomorphology" msgstr "地貌学" -#: src/natcap/invest/coastal_vulnerability.py:245 +#: src/natcap/invest/coastal_vulnerability.py:296 msgid "1: very low exposure" msgstr "1:极低暴露" -#: src/natcap/invest/coastal_vulnerability.py:246 +#: src/natcap/invest/coastal_vulnerability.py:297 msgid "2: low exposure" msgstr "2:低暴露" -#: src/natcap/invest/coastal_vulnerability.py:247 +#: src/natcap/invest/coastal_vulnerability.py:298 msgid "3: moderate exposure" msgstr "3:中度暴露" -#: src/natcap/invest/coastal_vulnerability.py:248 +#: src/natcap/invest/coastal_vulnerability.py:299 msgid "4: high exposure" msgstr "4:高暴露" -#: src/natcap/invest/coastal_vulnerability.py:249 +#: src/natcap/invest/coastal_vulnerability.py:300 msgid "5: very high exposure" msgstr "5:极高暴露" -#: src/natcap/invest/coastal_vulnerability.py:252 -msgid "Exposure rank to assign to any shore points that are not near to any segment in the geomorphology vector. Required if a Geomorphology vector is provided." +#: src/natcap/invest/coastal_vulnerability.py:303 +msgid "" +"Exposure rank to assign to any shore points that are not near to any " +"segment in the geomorphology vector. Required if a Geomorphology vector " +"is provided." msgstr "对任何不靠近地貌向量中任何区段的海岸点进行曝光等级分配。如果提供了地貌向量则需要。" -#: src/natcap/invest/coastal_vulnerability.py:256 +#: src/natcap/invest/coastal_vulnerability.py:307 msgid "geomorphology fill value" msgstr "地貌填充值" -#: src/natcap/invest/coastal_vulnerability.py:264 +#: src/natcap/invest/coastal_vulnerability.py:315 msgid "Map of total human population on each pixel." msgstr "每个栅格上的总人口地图。" -#: src/natcap/invest/coastal_vulnerability.py:265 +#: src/natcap/invest/coastal_vulnerability.py:316 msgid "human population" msgstr "人口" -#: src/natcap/invest/coastal_vulnerability.py:272 -msgid "The radius around each shore point within which to compute the average population density. Required if a Human Population map is provided." +#: src/natcap/invest/coastal_vulnerability.py:323 +msgid "" +"The radius around each shore point within which to compute the average " +"population density. Required if a Human Population map is provided." msgstr "计算平均人口密度的每个海岸点周围的半径。如果提供人类人口地图,则需要。" -#: src/natcap/invest/coastal_vulnerability.py:276 +#: src/natcap/invest/coastal_vulnerability.py:327 msgid "population search radius" msgstr "人口搜索半径" -#: src/natcap/invest/coastal_vulnerability.py:282 -msgid "Sea level rise rate or amount. This field name must be chosen as the Sea Level Rise Field." +#: src/natcap/invest/coastal_vulnerability.py:333 +msgid "" +"Sea level rise rate or amount. This field name must be chosen as the Sea " +"Level Rise Field." msgstr "海平面上升率或数量。这个字段名必须选择为海平面上升字段。" -#: src/natcap/invest/coastal_vulnerability.py:291 -msgid "Map of sea level rise rates or amounts. May be any sea level rise metric of interest, such as rate, or net rise/fall." +#: src/natcap/invest/coastal_vulnerability.py:342 +msgid "" +"Map of sea level rise rates or amounts. May be any sea level rise metric " +"of interest, such as rate, or net rise/fall." msgstr "海平面上升率或数量的地图。可以是任何感兴趣的海平面上升指标,如速率,或净上升/下降。" -#: src/natcap/invest/coastal_vulnerability.py:294 +#: src/natcap/invest/coastal_vulnerability.py:345 msgid "sea level rise" msgstr "海平面上升" -#: src/natcap/invest/coastal_vulnerability.py:300 -msgid "Name of the field in the sea level rise vector which contains the sea level rise metric of interest. Required if a Sea Level Rise vector is provided." +#: src/natcap/invest/coastal_vulnerability.py:351 +msgid "" +"Name of the field in the sea level rise vector which contains the sea " +"level rise metric of interest. Required if a Sea Level Rise vector is " +"provided." msgstr "海平面上升矢量中包含感兴趣的海平面上升指标的字段名称。如果提供了海平面上升矢量,则需要。" -#: src/natcap/invest/coastal_vulnerability.py:304 +#: src/natcap/invest/coastal_vulnerability.py:355 msgid "sea level rise field" msgstr "海平面上升边界" -#: src/natcap/invest/crop_production_percentile.py:96 -msgid "A table that maps each LULC code from the LULC map to one of the 175 canonical crop names representing the crop grown in that LULC class." +#: src/natcap/invest/crop_production_percentile.py:135 +msgid "" +"A table that maps each LULC code from the LULC map to one of the 175 " +"canonical crop names representing the crop grown in that LULC class." msgstr "一个表格,将LULC地图中的每个LULC代码与代表该LULC等级中种植的175个典型的作物名称之一进行映射。" -#: src/natcap/invest/crop_production_percentile.py:100 +#: src/natcap/invest/crop_production_percentile.py:139 msgid "LULC to Crop Table" msgstr "LULC与作物对应表" -#: src/natcap/invest/crop_production_percentile.py:112 +#: src/natcap/invest/crop_production_percentile.py:151 msgid "Table mapping each climate bin to yield percentiles for each crop." msgstr "每个气候仓与每种作物的产量百分比的映射表。" -#: src/natcap/invest/crop_production_percentile.py:142 +#: src/natcap/invest/crop_production_percentile.py:182 +#: src/natcap/invest/crop_production_regression.py:169 msgid "Maps of climate bins for each crop." msgstr "每种作物的气候区间图。" -#: src/natcap/invest/crop_production_percentile.py:152 +#: src/natcap/invest/crop_production_percentile.py:192 +#: src/natcap/invest/crop_production_regression.py:179 msgid "Maps of actual observed yield for each crop." msgstr "每种作物的实际观察产量图。" -#: src/natcap/invest/crop_production_percentile.py:207 +#: src/natcap/invest/crop_production_percentile.py:221 msgid "Path to the InVEST Crop Production Data directory." msgstr "InVEST作物生产数据目录的路径。" -#: src/natcap/invest/crop_production_percentile.py:208 +#: src/natcap/invest/crop_production_percentile.py:222 msgid "model data directory" msgstr "模型数据目录" -#: src/natcap/invest/crop_production_regression.py:23 +#: src/natcap/invest/crop_production_regression.py:22 msgid "barley" msgstr "大麦" -#: src/natcap/invest/crop_production_regression.py:24 +#: src/natcap/invest/crop_production_regression.py:23 msgid "maize" msgstr "玉米" -#: src/natcap/invest/crop_production_regression.py:25 +#: src/natcap/invest/crop_production_regression.py:24 msgid "oil palm" msgstr "棕榈油" -#: src/natcap/invest/crop_production_regression.py:26 +#: src/natcap/invest/crop_production_regression.py:25 msgid "potato" msgstr "马铃薯" -#: src/natcap/invest/crop_production_regression.py:27 +#: src/natcap/invest/crop_production_regression.py:26 msgid "rice" msgstr "大米" -#: src/natcap/invest/crop_production_regression.py:28 +#: src/natcap/invest/crop_production_regression.py:27 msgid "soybean" msgstr "大豆" -#: src/natcap/invest/crop_production_regression.py:29 +#: src/natcap/invest/crop_production_regression.py:28 msgid "sugar beet" msgstr "甜菜" -#: src/natcap/invest/crop_production_regression.py:30 +#: src/natcap/invest/crop_production_regression.py:29 msgid "sugarcane" msgstr "甘蔗" -#: src/natcap/invest/crop_production_regression.py:31 +#: src/natcap/invest/crop_production_regression.py:30 msgid "wheat" msgstr "小麦" -#: src/natcap/invest/crop_production_regression.py:61 -msgid "A table that maps each LULC code from the LULC map to one of the 10 canonical crop names representing the crop grown in that LULC class." +#: src/natcap/invest/crop_production_regression.py:96 +msgid "" +"A table that maps each LULC code from the LULC map to one of the 10 " +"canonical crop names representing the crop grown in that LULC class." msgstr "一个表将每个LULC代码从LULC映射到代表在该LULC类中生长的作物的10个规范作物名称中的一个。" -#: src/natcap/invest/crop_production_regression.py:65 +#: src/natcap/invest/crop_production_regression.py:100 msgid "LULC to crop table" msgstr "LULC与作物对应表" -#: src/natcap/invest/crop_production_regression.py:73 +#: src/natcap/invest/crop_production_regression.py:109 msgid "One of the supported crop types." msgstr "受支持的作物类型之一。" -#: src/natcap/invest/crop_production_regression.py:81 +#: src/natcap/invest/crop_production_regression.py:117 msgid "A table that maps crops to fertilizer application rates." msgstr "将作物与化肥施用量相对应的表格。" -#: src/natcap/invest/crop_production_regression.py:83 +#: src/natcap/invest/crop_production_regression.py:119 msgid "fertilization rate table" msgstr "施肥率表" -#: src/natcap/invest/crop_production_regression.py:156 +#: src/natcap/invest/crop_production_regression.py:191 msgid "The Crop Production datasets provided with the model." msgstr "模型提供的作物生产数据集。" -#: src/natcap/invest/crop_production_regression.py:157 +#: src/natcap/invest/crop_production_regression.py:192 msgid "model data" msgstr "模型数据" -#: src/natcap/invest/forest_carbon_edge_effect.py:50 -msgid "Number of closest regression models that are used when calculating the total biomass. Each local model is linearly weighted by distance such that the pixel's biomass is a function of each of these points with the closest point having the largest effect. Must be an integer greater than 0. Required if Compute Forest Edge Effects is selected." +#: src/natcap/invest/forest_carbon_edge_effect.py:51 +msgid "" +"Number of closest regression models that are used when calculating the " +"total biomass. Each local model is linearly weighted by distance such " +"that the pixel's biomass is a function of each of these points with the " +"closest point having the largest effect. Must be an integer greater than " +"0. Required if Compute Forest Edge Effects is selected." msgstr "计算总生物量时使用的最接近的回归模型的数目。每个局部模型都按距离线性加权,这样像素的生物量是这些点的函数,最近的点具有最大的影响。必须为大于0的整数。如果选中“计算森林边缘效果”,则需要。" -#: src/natcap/invest/forest_carbon_edge_effect.py:58 +#: src/natcap/invest/forest_carbon_edge_effect.py:59 msgid "number of points to average" msgstr "平均分数" -#: src/natcap/invest/forest_carbon_edge_effect.py:71 -msgid "Enter 1 if the LULC class is tropical forest, 0 if it is not tropical forest." +#: src/natcap/invest/forest_carbon_edge_effect.py:73 +msgid "" +"Enter 1 if the LULC class is tropical forest, 0 if it is not tropical " +"forest." msgstr "如果LULC类是热带森林,则输入1,如果不是热带森林,则输入0。" -#: src/natcap/invest/forest_carbon_edge_effect.py:77 +#: src/natcap/invest/forest_carbon_edge_effect.py:79 msgid "Carbon density value for the aboveground carbon pool." msgstr "地上碳库的碳密度值。" -#: src/natcap/invest/forest_carbon_edge_effect.py:85 -msgid "Carbon density value for the belowground carbon pool. Required if calculating all pools." +#: src/natcap/invest/forest_carbon_edge_effect.py:87 +msgid "" +"Carbon density value for the belowground carbon pool. Required if " +"calculating all pools." msgstr "地下碳库的碳密度值。如果计算所有碳库,则必须。" -#: src/natcap/invest/forest_carbon_edge_effect.py:93 -msgid "Carbon density value for the soil carbon pool. Required if calculating all pools." +#: src/natcap/invest/forest_carbon_edge_effect.py:95 +msgid "" +"Carbon density value for the soil carbon pool. Required if calculating " +"all pools." msgstr "土壤碳库的碳密度值。如果计算所有碳库,则必须。" -#: src/natcap/invest/forest_carbon_edge_effect.py:101 -msgid "Carbon density value for the dead matter carbon pool. Required if calculating all pools." +#: src/natcap/invest/forest_carbon_edge_effect.py:103 +msgid "" +"Carbon density value for the dead matter carbon pool. Required if " +"calculating all pools." msgstr "枯木碳库的碳密度值。如果计算所有碳库,则必须。" -#: src/natcap/invest/forest_carbon_edge_effect.py:106 -msgid "A table mapping each LULC code from the LULC map to biophysical data for that LULC class." +#: src/natcap/invest/forest_carbon_edge_effect.py:108 +msgid "" +"A table mapping each LULC code from the LULC map to biophysical data for " +"that LULC class." msgstr "将每个LULC代码从LULC映射到该LULC类的生物物理数据的表。" -#: src/natcap/invest/forest_carbon_edge_effect.py:122 +#: src/natcap/invest/forest_carbon_edge_effect.py:124 msgid "all" msgstr "全部" -#: src/natcap/invest/forest_carbon_edge_effect.py:123 -msgid "Use all pools (aboveground, belowground, soil, and dead matter) in the carbon pool calculation." +#: src/natcap/invest/forest_carbon_edge_effect.py:125 +msgid "" +"Use all pools (aboveground, belowground, soil, and dead matter) in the " +"carbon pool calculation." msgstr "在碳库计算中使用所有的碳库(地上、地下、土壤和枯木)。" -#: src/natcap/invest/forest_carbon_edge_effect.py:127 +#: src/natcap/invest/forest_carbon_edge_effect.py:129 msgid "aboveground only" msgstr "只在地面上" -#: src/natcap/invest/forest_carbon_edge_effect.py:128 +#: src/natcap/invest/forest_carbon_edge_effect.py:130 msgid "Only use the aboveground pool in the carbon pool calculation." msgstr "碳库计算只使用地上碳库。" -#: src/natcap/invest/forest_carbon_edge_effect.py:132 +#: src/natcap/invest/forest_carbon_edge_effect.py:134 msgid "Which carbon pools to consider." msgstr "要考虑哪个碳库。" -#: src/natcap/invest/forest_carbon_edge_effect.py:133 +#: src/natcap/invest/forest_carbon_edge_effect.py:135 msgid "carbon pools to calculate" msgstr "要计算的碳库" -#: src/natcap/invest/forest_carbon_edge_effect.py:137 +#: src/natcap/invest/forest_carbon_edge_effect.py:139 msgid "Account for forest edge effects on aboveground carbon." msgstr "考虑森林边缘对地上碳的影响。" -#: src/natcap/invest/forest_carbon_edge_effect.py:138 +#: src/natcap/invest/forest_carbon_edge_effect.py:140 msgid "compute forest edge effects" msgstr "计算森林边缘效应" -#: src/natcap/invest/forest_carbon_edge_effect.py:146 +#: src/natcap/invest/forest_carbon_edge_effect.py:148 msgid "asymptotic" msgstr "渐近的" -#: src/natcap/invest/forest_carbon_edge_effect.py:147 +#: src/natcap/invest/forest_carbon_edge_effect.py:149 msgid "logarithmic" msgstr "对数的" -#: src/natcap/invest/forest_carbon_edge_effect.py:148 +#: src/natcap/invest/forest_carbon_edge_effect.py:150 msgid "linear" msgstr "线性的" -#: src/natcap/invest/forest_carbon_edge_effect.py:150 +#: src/natcap/invest/forest_carbon_edge_effect.py:152 msgid "Optimal regression model for the area." msgstr "该地区的最佳回归模型。" -#: src/natcap/invest/forest_carbon_edge_effect.py:155 +#: src/natcap/invest/forest_carbon_edge_effect.py:157 msgid "θ₁ parameter for the regression equation." msgstr "θ₁为回归方程的参数。" -#: src/natcap/invest/forest_carbon_edge_effect.py:159 +#: src/natcap/invest/forest_carbon_edge_effect.py:161 msgid "θ₂ parameter for the regression equation." msgstr "回归方程的θ₂参数。" -#: src/natcap/invest/forest_carbon_edge_effect.py:163 -msgid "θ₃ parameter for the regression equation. Used only for the asymptotic model." +#: src/natcap/invest/forest_carbon_edge_effect.py:165 +msgid "" +"θ₃ parameter for the regression equation. Used only for the asymptotic " +"model." msgstr "回归方程的θ₃参数。仅用于渐近模型。" -#: src/natcap/invest/forest_carbon_edge_effect.py:169 -msgid "Map storing the optimal regression model for each tropical subregion and the corresponding theta parameters for that regression equation. Default data is provided. Required if Compute Forest Edge Effects is selected." +#: src/natcap/invest/forest_carbon_edge_effect.py:171 +msgid "" +"Map storing the optimal regression model for each tropical subregion and " +"the corresponding theta parameters for that regression equation. Default " +"data is provided. Required if Compute Forest Edge Effects is selected." msgstr "储存每个热带次区域的最佳回归模型和该回归方程的相应theta参数的地图。提供默认数据。如果选择 \"计算森林边缘效应 \"则需要。" -#: src/natcap/invest/forest_carbon_edge_effect.py:174 +#: src/natcap/invest/forest_carbon_edge_effect.py:176 msgid "global regression models" msgstr "全球回归模型" -#: src/natcap/invest/forest_carbon_edge_effect.py:179 -msgid "Proportion of forest edge biomass that is elemental carbon. Required if Compute Forest Edge Effects is selected." +#: src/natcap/invest/forest_carbon_edge_effect.py:181 +msgid "" +"Proportion of forest edge biomass that is elemental carbon. Required if " +"Compute Forest Edge Effects is selected." msgstr "森林边缘生物量中元素碳的比例。如果选择 \"计算森林边缘效应 \"则需要。" -#: src/natcap/invest/forest_carbon_edge_effect.py:182 +#: src/natcap/invest/forest_carbon_edge_effect.py:184 msgid "forest edge biomass to carbon conversion factor" msgstr "林缘生物量与碳的转换系数" -#: src/natcap/invest/habitat_quality.py:22 -msgid "Threats {threats} does not match any column in the sensitivity table. Sensitivity columns: {column_names}" +#: src/natcap/invest/habitat_quality.py:21 +msgid "" +"Threats {threats} does not match any column in the sensitivity table. " +"Sensitivity columns: {column_names}" msgstr "威胁{threats}与敏感度表中的任何列不匹配。敏感度列。{column_names}" -#: src/natcap/invest/habitat_quality.py:25 -msgid "The column '{column_name}' was not found in the Threat Data table for the corresponding input LULC scenario." -msgstr "在相应的输入LULC情景的威胁数据表中没有找到\"{column_name}\"列。" - -#: src/natcap/invest/habitat_quality.py:28 -msgid "A threat raster for threats: {threat_list} was not found or it could not be opened by GDAL." +#: src/natcap/invest/habitat_quality.py:24 +msgid "" +"A threat raster for threats: {threat_list} was not found or it could not " +"be opened by GDAL." msgstr "威胁的栅格。{threat_list}没有找到,或者它不能被GDAL打开。" -#: src/natcap/invest/habitat_quality.py:31 +#: src/natcap/invest/habitat_quality.py:27 msgid "Threat paths must be unique. Duplicates: " msgstr "威胁路径必须是唯一的。重复的: " -#: src/natcap/invest/habitat_quality.py:50 -msgid "Map of LULC at present. All values in this raster must have corresponding entries in the Sensitivity table." +#: src/natcap/invest/habitat_quality.py:46 +msgid "" +"Map of LULC at present. All values in this raster must have corresponding" +" entries in the Sensitivity table." msgstr "目前LULC的地图。该栅格中的所有数值都必须在敏感度表中有相应的条目。" -#: src/natcap/invest/habitat_quality.py:53 +#: src/natcap/invest/habitat_quality.py:49 msgid "current land cover" msgstr "现状土地覆盖" -#: src/natcap/invest/habitat_quality.py:59 -msgid "Map of LULC in a future scenario. All values in this raster must have corresponding entries in the Sensitivity Table. Must use the same classification scheme and codes as in the Current LULC map." +#: src/natcap/invest/habitat_quality.py:55 +msgid "" +"Map of LULC in a future scenario. All values in this raster must have " +"corresponding entries in the Sensitivity Table. Must use the same " +"classification scheme and codes as in the Current LULC map." msgstr "未来情景下的LULC地图。该栅格中的所有数值必须在敏感度表中有相应的条目。必须使用与当前LULC地图中相同的分类方案和代码。" -#: src/natcap/invest/habitat_quality.py:64 +#: src/natcap/invest/habitat_quality.py:60 msgid "future land cover" msgstr "未来土地覆盖" -#: src/natcap/invest/habitat_quality.py:70 -msgid "Map of LULC in a baseline scenario, when intensive landscape management was relatively rare. All values in this raster must have corresponding entries in the Sensitivity table. Must use the same classification scheme and codes as in the Current LULC map." +#: src/natcap/invest/habitat_quality.py:66 +msgid "" +"Map of LULC in a baseline scenario, when intensive landscape management " +"was relatively rare. All values in this raster must have corresponding " +"entries in the Sensitivity table. Must use the same classification scheme" +" and codes as in the Current LULC map." msgstr "基线情景下的LULC地图,当时密集的景观管理相对罕见。该栅格中的所有数值必须在敏感度表中有相应的条目。必须使用与当前LULC地图中相同的分类方案和代码。" -#: src/natcap/invest/habitat_quality.py:76 +#: src/natcap/invest/habitat_quality.py:72 msgid "baseline land cover" msgstr "基线土地覆盖" -#: src/natcap/invest/habitat_quality.py:83 -msgid "Name of the threat. Each threat name must have a corresponding column in the Sensitivity table." +#: src/natcap/invest/habitat_quality.py:80 +msgid "" +"Name of the threat. Each threat name must have a corresponding column in " +"the Sensitivity table." msgstr "威胁的名称。每个威胁名称必须在敏感度表中有一个相应的列。" -#: src/natcap/invest/habitat_quality.py:89 -msgid "The maximum distance over which each threat affects habitat quality. The impact of each degradation source will decline to zero at this maximum distance. This value must be greater than or equal to the pixel size of your LULC raster(s)." +#: src/natcap/invest/habitat_quality.py:86 +msgid "" +"The maximum distance over which each threat affects habitat quality. The " +"impact of each degradation source will decline to zero at this maximum " +"distance. This value must be greater than or equal to the pixel size of " +"your LULC raster(s)." msgstr "每个威胁影响生境质量的最大距离。每个退化源的影响在这个最大距离上会下降到零。这个值必须大于或等于你的LULC栅格的像素大小。" -#: src/natcap/invest/habitat_quality.py:98 +#: src/natcap/invest/habitat_quality.py:95 msgid "The impact of each threat on habitat quality, relative to other threats." msgstr "相对于其他威胁,每种威胁对栖息地质量的影响。" -#: src/natcap/invest/habitat_quality.py:106 +#: src/natcap/invest/habitat_quality.py:103 msgid "Effects of the threat decay linearly with distance from the threat." msgstr "威胁的影响随着距离威胁的距离线性衰减。" -#: src/natcap/invest/habitat_quality.py:110 +#: src/natcap/invest/habitat_quality.py:107 msgid "Effects of the threat decay exponentially with distance from the threat." msgstr "威胁的影响随着距离威胁的距离呈指数级衰减。" -#: src/natcap/invest/habitat_quality.py:114 +#: src/natcap/invest/habitat_quality.py:111 msgid "The type of decay over space for each threat." msgstr "每种威胁在空间上的衰减类型。" -#: src/natcap/invest/habitat_quality.py:119 -msgid "Map of the threat's distribution in the current scenario. Each pixel value is the relative intensity of the threat at that location. " +#: src/natcap/invest/habitat_quality.py:116 +#, fuzzy +msgid "" +"Path to a raster of the threat's distribution in the current scenario. " +"Each pixel value in this raster is the relative intensity of the threat " +"at that location, with values between 0 and 1." msgstr "当前场景下的威胁分布图。每个像素值都是该位置威胁的相对强度。 " -#: src/natcap/invest/habitat_quality.py:128 -msgid "Map of the threat's distribution in the future scenario. Each pixel value is the relative intensity of the threat at that location. Required if Future LULC is provided." -msgstr "威胁在未来场景中的分布图。每个像素值都是该位置威胁的相对强度。如果提供未来LULC,则必须。" +#: src/natcap/invest/habitat_quality.py:127 +#, fuzzy +msgid "" +"Path to a raster of the threat's distribution in a future scenario. Each " +"pixel value in this raster is the relative intensity of the threat at " +"that location, with values between 0 and 1." +msgstr "当前场景下的威胁分布图。每个像素值都是该位置威胁的相对强度。 " #: src/natcap/invest/habitat_quality.py:138 -msgid "Map of the threat's distribution in the baseline scenario. Each pixel value is the relative intensity of the threat at that location. Required if Baseline LULC is provided." +#, fuzzy +msgid "" +"Path to a raster of the threat's distribution in the baseline scenario. " +"Each pixel value in this raster is the relative intensity of the threat " +"at that location, with values between 0 and 1. Required if Baseline LULC " +"is provided." msgstr "基线场景中威胁分布的地图。每个像素值都是该位置威胁的相对强度。如果提供了基线LULC,则需要。" -#: src/natcap/invest/habitat_quality.py:145 -msgid "Table mapping each threat of interest to its properties and distribution maps. Paths are relative to the threats table path." +#: src/natcap/invest/habitat_quality.py:146 +msgid "" +"Table mapping each threat of interest to its properties and distribution " +"maps. Paths are relative to the threats table path." msgstr "表将每个感兴趣威胁的属性和映射。路径相对于威胁表路径。" -#: src/natcap/invest/habitat_quality.py:149 +#: src/natcap/invest/habitat_quality.py:150 msgid "threats table" msgstr "威胁表格" -#: src/natcap/invest/habitat_quality.py:157 -msgid "The region's relative accessibility to threats, where 0 represents completely inaccessible and 1 represents completely accessible." +#: src/natcap/invest/habitat_quality.py:158 +msgid "" +"The region's relative accessibility to threats, where 0 represents " +"completely inaccessible and 1 represents completely accessible." msgstr "该区域对威胁的相对可达性,其中0表示完全不可达,1表示完全可达。" -#: src/natcap/invest/habitat_quality.py:165 -msgid "Map of the relative protection that legal, institutional, social, and physical barriers provide against threats. Any cells not covered by a polygon will be set to 1." +#: src/natcap/invest/habitat_quality.py:166 +msgid "" +"Map of the relative protection that legal, institutional, social, and " +"physical barriers provide against threats. Any cells not covered by a " +"polygon will be set to 1." msgstr "法律、制度、社会和物理障碍对威胁的相对保护。任何未被多边形覆盖的单元格将被设置为1。" -#: src/natcap/invest/habitat_quality.py:169 +#: src/natcap/invest/habitat_quality.py:170 msgid "accessibility to threats" msgstr "威胁的可达性" -#: src/natcap/invest/habitat_quality.py:177 -msgid "Suitability of this LULC class as habitat, where 0 is not suitable and 1 is completely suitable." +#: src/natcap/invest/habitat_quality.py:183 +msgid "" +"Suitability of this LULC class as habitat, where 0 is not suitable and 1 " +"is completely suitable." msgstr "该LULC类生境的适宜性,0为不适宜,1为完全适宜。" -#: src/natcap/invest/habitat_quality.py:183 -msgid "The relative sensitivity of each LULC class to each type of threat, where 1 represents high sensitivity and 0 represents that it is unaffected. There must be one threat column for each threat name in the 'threats' column of the Threats Table." +#: src/natcap/invest/habitat_quality.py:189 +msgid "" +"The relative sensitivity of each LULC class to each type of threat, where" +" 1 represents high sensitivity and 0 represents that it is unaffected. " +"There must be one threat column for each threat name in the 'threats' " +"column of the Threats Table." msgstr "每个LULC类对每种威胁类型的相对敏感性,其中1表示高敏感性,0表示不受影响。在“威胁表”的“威胁”列中,每个威胁必须有一个对应列。" -#: src/natcap/invest/habitat_quality.py:191 -msgid "Table mapping each LULC class to data about the species' habitat preference and threat sensitivity in areas with that LULC." +#: src/natcap/invest/habitat_quality.py:197 +msgid "" +"Table mapping each LULC class to data about the species' habitat " +"preference and threat sensitivity in areas with that LULC." msgstr "将每个LULC类映射到具有该LULC区域的物种栖息地偏好和威胁敏感性的数据。" -#: src/natcap/invest/habitat_quality.py:195 +#: src/natcap/invest/habitat_quality.py:201 msgid "sensitivity table" msgstr "敏感性表格" -#: src/natcap/invest/habitat_quality.py:201 +#: src/natcap/invest/habitat_quality.py:207 msgid "Half-saturation constant used in the degradation equation." msgstr "退化公式中使用的半饱和常数。" -#: src/natcap/invest/habitat_quality.py:203 +#: src/natcap/invest/habitat_quality.py:209 msgid "half-saturation constant" msgstr "半包和常数" -#: src/natcap/invest/hra.py:66 +#: src/natcap/invest/hra.py:61 msgid "habitat stressor table" msgstr "生境压力源表" -#: src/natcap/invest/hra.py:67 +#: src/natcap/invest/hra.py:62 msgid "A table describing each habitat and stressor." msgstr "描述每个生境和压力源的表格。" -#: src/natcap/invest/hra.py:72 -msgid "A unique name for each habitat or stressor. These names must match the habitat and stressor names in the Criteria Scores Table." +#: src/natcap/invest/hra.py:68 +msgid "" +"A unique name for each habitat or stressor. These names must match the " +"habitat and stressor names in the Criteria Scores Table." msgstr "每个生境或压力源的唯一名称。这些名称必须符合标准评分表中的生境和压力源名称。" -#: src/natcap/invest/hra.py:81 -msgid "Pixel values are 1, indicating presence of the habitat/stressor, or 0 indicating absence. Any values besides 0 or 1 will be treated as 0." +#: src/natcap/invest/hra.py:77 +msgid "" +"Pixel values are 1, indicating presence of the habitat/stressor, or 0 " +"indicating absence. Any values besides 0 or 1 will be treated as 0." msgstr "栅格值为1,表示生境/压力源存在,或0表示不存在。除0或1以外的任何值都将被视为0。" -#: src/natcap/invest/hra.py:88 -msgid "Map of where the habitat or stressor exists. For rasters, a pixel value of 1 indicates presence of the habitat or stressor. 0 (or any other value) indicates absence of the habitat or stressor. For vectors, a polygon indicates an area where the habitat or stressor is present." +#: src/natcap/invest/hra.py:84 +msgid "" +"Map of where the habitat or stressor exists. For rasters, a pixel value " +"of 1 indicates presence of the habitat or stressor. 0 (or any other " +"value) indicates absence of the habitat or stressor. For vectors, a " +"polygon indicates an area where the habitat or stressor is present." msgstr "生境或压力源的分布图。对于栅格,值为1表示生境或压力源的存在。0(或任何其他值)表示没有生境或压力源。对于矢量,多边形表示生境或压力源存在的区域。" -#: src/natcap/invest/hra.py:99 +#: src/natcap/invest/hra.py:95 msgid "habitat" msgstr "生境" -#: src/natcap/invest/hra.py:100 +#: src/natcap/invest/hra.py:96 msgid "stressor" msgstr "压力源" -#: src/natcap/invest/hra.py:102 +#: src/natcap/invest/hra.py:98 msgid "Whether this row is for a habitat or a stressor." msgstr "不管这是用作生境还是用作压力源。" -#: src/natcap/invest/hra.py:108 -msgid "The desired buffer distance used to expand a given stressor’s influence or footprint. This should be left blank for habitats, but must be filled in for stressors. Enter 0 if no buffering is desired for a given stressor. The model will round down this buffer distance to the nearest cell unit. e.g., a buffer distance of 600m will buffer a stressor’s footprint by two grid cells if the resolution of analysis is 250m." -msgstr "用于扩大给定压力源的影响或影响范围的所需缓冲距离。这里应该为生境留下空白,但必须为压力源填写。如果给定的压力源不需要缓冲,则输入0。模型将把这个缓冲距离舍入到最近的栅格单元。例如,如果分析分辨率为250m, 600m的缓冲距离将用两个栅格单元缓冲压力源的足迹。" +#: src/natcap/invest/hra.py:104 +msgid "" +"The desired buffer distance used to expand a given stressor’s influence " +"or footprint. This should be left blank for habitats, but must be filled " +"in for stressors. Enter 0 if no buffering is desired for a given " +"stressor. The model will round down this buffer distance to the nearest " +"cell unit. e.g., a buffer distance of 600m will buffer a stressor’s " +"footprint by two grid cells if the resolution of analysis is 250m." +msgstr "" +"用于扩大给定压力源的影响或影响范围的所需缓冲距离。这里应该为生境留下空白,但必须为压力源填写。如果给定的压力源不需要缓冲,则输入0。模型将把这个缓冲距离舍入到最近的栅格单元。例如,如果分析分辨率为250m," +" 600m的缓冲距离将用两个栅格单元缓冲压力源的足迹。" -#: src/natcap/invest/hra.py:123 +#: src/natcap/invest/hra.py:118 msgid "criteria scores table" msgstr "标准评分表" -#: src/natcap/invest/hra.py:124 +#: src/natcap/invest/hra.py:119 msgid "A table of criteria scores for all habitats and stressors." msgstr "所有生境和压力源的标准评分表。" -#: src/natcap/invest/hra.py:130 +#: src/natcap/invest/hra.py:124 msgid "resolution of analysis" msgstr "分析的决议" -#: src/natcap/invest/hra.py:131 -msgid "The resolution at which to run the analysis. The model outputs will have this resolution." +#: src/natcap/invest/hra.py:125 +msgid "" +"The resolution at which to run the analysis. The model outputs will have " +"this resolution." msgstr "运行分析的分辨率。模型将输出这个分辨率。" -#: src/natcap/invest/hra.py:139 +#: src/natcap/invest/hra.py:133 msgid "maximum criteria score" msgstr "最高标准得分" -#: src/natcap/invest/hra.py:140 +#: src/natcap/invest/hra.py:134 msgid "The highest possible criteria score in the scoring system." msgstr "打分系统中可能的最高标准得分。" -#: src/natcap/invest/hra.py:147 +#: src/natcap/invest/hra.py:141 msgid "risk equation" msgstr "风险方程" -#: src/natcap/invest/hra.py:148 +#: src/natcap/invest/hra.py:142 msgid "The equation to use to calculate risk from exposure and consequence." msgstr "用来计算暴露和后果的风险的方程式。" -#: src/natcap/invest/hra.py:153 +#: src/natcap/invest/hra.py:147 msgid "Multiplicative" msgstr "乘法" -#: src/natcap/invest/hra.py:154 +#: src/natcap/invest/hra.py:148 msgid "Euclidean" msgstr "欧几里德" -#: src/natcap/invest/hra.py:158 +#: src/natcap/invest/hra.py:152 msgid "decay equation" msgstr "衰变方程" -#: src/natcap/invest/hra.py:159 +#: src/natcap/invest/hra.py:153 msgid "The equation to model effects of stressors in buffer areas." msgstr "缓冲区内压力源效应的模型方程。" -#: src/natcap/invest/hra.py:164 +#: src/natcap/invest/hra.py:158 msgid "None" msgstr "无" -#: src/natcap/invest/hra.py:165 +#: src/natcap/invest/hra.py:159 msgid "No decay. Stressor has full effect in the buffer area." msgstr "没有衰变。压迫物在缓冲区内有充分的效果。" -#: src/natcap/invest/hra.py:169 +#: src/natcap/invest/hra.py:163 msgid "Linear" msgstr "线性" -#: src/natcap/invest/hra.py:170 -msgid "Stressor effects in the buffer area decay linearly with distance from the stressor." +#: src/natcap/invest/hra.py:164 +msgid "" +"Stressor effects in the buffer area decay linearly with distance from the" +" stressor." msgstr "缓冲区内的压力源效应随着与压力源的距离线性衰减。" -#: src/natcap/invest/hra.py:174 +#: src/natcap/invest/hra.py:168 msgid "Exponential" msgstr "指数型" -#: src/natcap/invest/hra.py:175 -msgid "Stressor effects in the buffer area decay exponentially with distance from the stressor." +#: src/natcap/invest/hra.py:169 +msgid "" +"Stressor effects in the buffer area decay exponentially with distance " +"from the stressor." msgstr "缓冲区内的压迫物效应随着与压迫物的距离呈指数级衰减。" -#: src/natcap/invest/hra.py:188 -msgid "Uniquely identifies each feature. Required if the vector contains more than one feature." +#: src/natcap/invest/hra.py:182 +msgid "" +"Uniquely identifies each feature. Required if the vector contains more " +"than one feature." msgstr "独特地识别每个特征。如果向量包含一个以上的特征,则需要。" -#: src/natcap/invest/hra.py:193 -msgid "A GDAL-supported vector file containing features representing one or more planning regions or subregions." +#: src/natcap/invest/hra.py:187 +msgid "" +"A GDAL-supported vector file containing features representing one or more" +" planning regions or subregions." msgstr "一个GDAL支持的矢量文件,包含代表一个或多个规划区域或次区域的特征。" -#: src/natcap/invest/hra.py:198 +#: src/natcap/invest/hra.py:192 msgid "Number of Overlapping Stressors" msgstr "重叠的压力源的数量" -#: src/natcap/invest/hra.py:201 -msgid "The number of overlapping stressors to consider as 'maximum' when reclassifying risk scores into high/medium/low. Affects the breaks between risk classifications." +#: src/natcap/invest/hra.py:195 +msgid "" +"The number of overlapping stressors to consider as 'maximum' when " +"reclassifying risk scores into high/medium/low. Affects the breaks " +"between risk classifications." msgstr "在将风险分数重新分类为高/中/低时,将重叠的压力源的数量视为 \"最大\"。 影响到风险分类之间的断裂。" -#: src/natcap/invest/hra.py:210 +#: src/natcap/invest/hra.py:204 msgid "Generate GeoJSONs" msgstr "生成GeoJSONs" -#: src/natcap/invest/hra.py:211 +#: src/natcap/invest/hra.py:205 msgid "Generate GeoJSON outputs for web visualization." msgstr "生成用于网络可视化的GeoJSON输出。" @@ -1054,236 +1266,403 @@ msgstr "缓解城市洪水风险" msgid "Urban Cooling" msgstr "城市降温" +#: src/natcap/invest/model_metadata.py:162 +msgid "Urban Nature Access" +msgstr "" + #: src/natcap/invest/pollination.py:37 -msgid "Map of LULC codes. All values in this raster must have corresponding entries in the Biophysical Table." +msgid "" +"Map of LULC codes. All values in this raster must have corresponding " +"entries in the Biophysical Table." msgstr "LULC代码的地图。该栅格中的所有数值必须在生物物理表中有相应的条目。" -#: src/natcap/invest/pollination.py:46 -msgid "Unique name or identifier for each pollinator species or guild of interest." +#: src/natcap/invest/pollination.py:47 +msgid "" +"Unique name or identifier for each pollinator species or guild of " +"interest." msgstr "每个传粉者物种的唯一名称或标识符。" -#: src/natcap/invest/pollination.py:52 -msgid "Utilization of the substrate by this species, where 1 indicates the nesting substrate is fully utilized and 0 indicates it is not utilized at all. Replace [SUBSTRATE] with substrate names matching those in the Biophysical Table, so that there is a column for each substrate." +#: src/natcap/invest/pollination.py:53 +msgid "" +"Utilization of the substrate by this species, where 1 indicates the " +"nesting substrate is fully utilized and 0 indicates it is not utilized at" +" all. Replace [SUBSTRATE] with substrate names matching those in the " +"Biophysical Table, so that there is a column for each substrate." msgstr "该物种对基质的利用情况,其中1表示筑巢基质被充分利用,0表示完全没有利用。用生物物理表中匹配的底物名称替换[SUBSTRATE],这样每个底物都有一个列。" -#: src/natcap/invest/pollination.py:62 -msgid "Pollinator activity for this species/guild in each season. 1 indicates maximum activity for the species/guild, and 0 indicates no activity. Replace [SEASON] with season names matching those in the biophysical table, so that there is a column for each season." +#: src/natcap/invest/pollination.py:63 +msgid "" +"Pollinator activity for this species/guild in each season. 1 indicates " +"maximum activity for the species/guild, and 0 indicates no activity. " +"Replace [SEASON] with season names matching those in the biophysical " +"table, so that there is a column for each season." msgstr "本物种/公会在每个季节的传粉者活动。1表示该物种/公会的最大活动,0表示没有活动。用生物物理表中匹配的季节名替换[SEASON],这样每个季节都有一个列。" -#: src/natcap/invest/pollination.py:73 +#: src/natcap/invest/pollination.py:74 msgid "Average distance that this species or guild travels to forage on flowers." msgstr "这个物种或公会在花上觅食的平均距离。" -#: src/natcap/invest/pollination.py:79 -msgid "The proportion of total pollinator abundance that consists of this species/guild." +#: src/natcap/invest/pollination.py:80 +msgid "" +"The proportion of total pollinator abundance that consists of this " +"species/guild." msgstr "由该物种/协会组成的传粉者总数的比例。" -#: src/natcap/invest/pollination.py:84 -msgid "A table mapping each pollinator species or guild of interest to its pollination-related parameters." +#: src/natcap/invest/pollination.py:85 +msgid "" +"A table mapping each pollinator species or guild of interest to its " +"pollination-related parameters." msgstr "一个表,将每一个传粉者物种或感兴趣的协会的传粉相关参数。" -#: src/natcap/invest/pollination.py:87 +#: src/natcap/invest/pollination.py:88 msgid "Guild Table" msgstr "公会表" -#: src/natcap/invest/pollination.py:95 -msgid "Index of availability of the given substrate in this LULC class. Replace [SUBSTRATE] with substrate names matching those in the Guild Table, so that there is a column for each substrate." +#: src/natcap/invest/pollination.py:97 +msgid "" +"Index of availability of the given substrate in this LULC class. Replace " +"[SUBSTRATE] with substrate names matching those in the Guild Table, so " +"that there is a column for each substrate." msgstr "该LULC类中给定基质的可用性索引。用与公会表中的基质名称相匹配的基质名称替换[SUBSTRATE],这样,每个基质都有一列。" -#: src/natcap/invest/pollination.py:102 -msgid "Abundance of flowers during the given season in this LULC class. This is the proportion of land area covered by flowers, multiplied by the proportion of the season for which there is that coverage. Replace [SEASON] with season names matching those in the Guild Table, so that there is a column for each season." +#: src/natcap/invest/pollination.py:104 +msgid "" +"Abundance of flowers during the given season in this LULC class. This is " +"the proportion of land area covered by flowers, multiplied by the " +"proportion of the season for which there is that coverage. Replace " +"[SEASON] with season names matching those in the Guild Table, so that " +"there is a column for each season." msgstr "该LULC等级在特定季节的花卉丰度。这是花卉覆盖的土地面积的比例,乘以有该覆盖的季节的比例。用与公会表中的季节名称相匹配的季节名称替换[SEASON],以便每个季节都有一列。" -#: src/natcap/invest/pollination.py:111 -msgid "A table mapping each LULC class to nesting availability and floral abundance data for each substrate and season in that LULC class. All values in the LULC raster must have corresponding entries in this table." +#: src/natcap/invest/pollination.py:113 +msgid "" +"A table mapping each LULC class to nesting availability and floral " +"abundance data for each substrate and season in that LULC class. All " +"values in the LULC raster must have corresponding entries in this table." msgstr "一个将每个LULC等级与该LULC等级中每个基质和季节的筑巢可用性和花卉丰度数据进行映射的表格。LULC栅格中的所有数值必须在此表中有相应的条目。" -#: src/natcap/invest/pollination.py:123 -msgid "Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', etc." +#: src/natcap/invest/pollination.py:125 +msgid "" +"Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', " +"etc." msgstr "每个多边形上种植的作物名称,如 \"蓝莓\"、\"杏仁 \"等。" -#: src/natcap/invest/pollination.py:128 -msgid "The half saturation coefficient for the crop grown in this area. This is the wild pollinator abundance (i.e. the proportion of all pollinators that are wild) needed to reach half of the total potential pollinator-dependent yield." +#: src/natcap/invest/pollination.py:130 +msgid "" +"The half saturation coefficient for the crop grown in this area. This is " +"the wild pollinator abundance (i.e. the proportion of all pollinators " +"that are wild) needed to reach half of the total potential pollinator-" +"dependent yield." msgstr "该地区种植的作物的半饱和系数。这是达到依赖授粉者的潜在总产量的一半所需的野生授粉者丰度(即所有授粉者中野生的比例)。" -#: src/natcap/invest/pollination.py:136 -msgid "The season in which the crop is pollinated. Season names must match those in the Guild Table and Biophysical Table." +#: src/natcap/invest/pollination.py:138 +msgid "" +"The season in which the crop is pollinated. Season names must match those" +" in the Guild Table and Biophysical Table." msgstr "作物授粉的季节。季节名称必须与公会表和生物物理表中的名称一致。" -#: src/natcap/invest/pollination.py:142 -msgid "The floral resources available at this farm for the given season. Replace [SEASON] with season names matching those in the Guild Table and Biophysical Table, so that there is one field for each season." +#: src/natcap/invest/pollination.py:144 +msgid "" +"The floral resources available at this farm for the given season. Replace" +" [SEASON] with season names matching those in the Guild Table and " +"Biophysical Table, so that there is one field for each season." msgstr "这个农场在给定季节可获得的花草资源。用与行会表和生物物理表相匹配的季节名称替换[SEASON],这样每个季节就有一个字段。" -#: src/natcap/invest/pollination.py:150 -msgid "The nesting suitability for the given substrate at this farm. given substrate. Replace [SUBSTRATE] with substrate names matching those in the Guild Table and Biophysical Table, so that there is one field for each substrate." +#: src/natcap/invest/pollination.py:152 +msgid "" +"The nesting suitability for the given substrate at this farm. given " +"substrate. Replace [SUBSTRATE] with substrate names matching those in the" +" Guild Table and Biophysical Table, so that there is one field for each " +"substrate." msgstr "该农场对给定基质的嵌套适用性。 给定基质。用与公会表和生物物理表中的基质名称相匹配的基质名称替换[SUBSTRATE],这样每个基质就有一个字段。" -#: src/natcap/invest/pollination.py:158 +#: src/natcap/invest/pollination.py:160 msgid "The proportion of crop dependent on pollinators." msgstr "依靠传粉者的作物比例。" -#: src/natcap/invest/pollination.py:163 -msgid "The proportion of pollination required on the farm that is provided by managed pollinators." +#: src/natcap/invest/pollination.py:165 +msgid "" +"The proportion of pollination required on the farm that is provided by " +"managed pollinators." msgstr "农场中由管理传粉者提供的传粉比例。" -#: src/natcap/invest/pollination.py:169 -msgid "Map of farm sites to be analyzed, with pollination data specific to each farm." +#: src/natcap/invest/pollination.py:171 +msgid "" +"Map of farm sites to be analyzed, with pollination data specific to each " +"farm." msgstr "要分析的农场地点的地图,每个农场的授粉数据。" -#: src/natcap/invest/pollination.py:172 +#: src/natcap/invest/pollination.py:174 msgid "farms map" msgstr "农场地图" -#: src/natcap/invest/routedem.py:20 +#: src/natcap/invest/pollination.py:180 +msgid "A copy of the input farm polygon vector file with additional fields" +msgstr "" + +#: src/natcap/invest/pollination.py:212 +msgid "" +"Total pollinator abundance across all species per season, clipped to the " +"geometry of the farm vector’s polygons." +msgstr "" + +#: src/natcap/invest/pollination.py:218 +msgid "Abundance of pollinator SPECIES in season SEASON." +msgstr "" + +#: src/natcap/invest/pollination.py:222 +msgid "" +"Index of pollinator SPECIES that could be on a pixel given its arbitrary " +"abundance factor from the table, multiplied by the habitat suitability " +"for that species at that pixel, multiplied by the available floral " +"resources that a pollinator could fly to from that pixel." +msgstr "" + +#: src/natcap/invest/pollination.py:232 +#, fuzzy +msgid "Total pollinator abundance across all species per season." +msgstr "由该物种/协会组成的传粉者总数的比例。" + +#: src/natcap/invest/pollination.py:238 +msgid "" +"Total pollinator yield index for pixels that overlap farms, including " +"wild and managed pollinators." +msgstr "" + +#: src/natcap/invest/pollination.py:245 +msgid "" +"Pollinator yield index for pixels that overlap farms, for wild " +"pollinators only." +msgstr "" + +#: src/natcap/invest/routedem.py:18 msgid "Must be between 1 and {maximum}" msgstr "必须在1和{maximum}之间" -#: src/natcap/invest/routedem.py:36 +#: src/natcap/invest/routedem.py:34 msgid "Index of the raster band to use, for multi-band rasters." msgstr "要使用的栅格波段的索引,用于多波段栅格。" -#: src/natcap/invest/routedem.py:38 +#: src/natcap/invest/routedem.py:36 msgid "band index" msgstr "波段索引" -#: src/natcap/invest/routedem.py:45 -msgid "All water on a pixel flows into the most downhill of its 8 surrounding pixels" +#: src/natcap/invest/routedem.py:43 +msgid "" +"All water on a pixel flows into the most downhill of its 8 surrounding " +"pixels" msgstr "一个栅格上的所有水都流入周围8个栅格中最下坡的一个" -#: src/natcap/invest/routedem.py:50 -msgid "Flow off a pixel is modeled fractionally so that water is split among multiple downslope pixels" +#: src/natcap/invest/routedem.py:48 +msgid "" +"Flow off a pixel is modeled fractionally so that water is split among " +"multiple downslope pixels" msgstr "一个栅格的流量是分段建模的,因此水在多个下斜坡栅格之间被分割" -#: src/natcap/invest/routedem.py:54 +#: src/natcap/invest/routedem.py:52 msgid "The routing algorithm to use." msgstr "要使用的路由算法。" -#: src/natcap/invest/routedem.py:55 +#: src/natcap/invest/routedem.py:53 msgid "routing algorithm" msgstr "路由算法" -#: src/natcap/invest/routedem.py:60 +#: src/natcap/invest/routedem.py:58 msgid "Calculate flow direction from the provided DEM." msgstr "根据所提供的DEM计算流向。" -#: src/natcap/invest/routedem.py:61 +#: src/natcap/invest/routedem.py:59 msgid "calculate flow direction" msgstr "计算流向" -#: src/natcap/invest/routedem.py:66 +#: src/natcap/invest/routedem.py:64 msgid "Calculate flow accumulation from the flow direction output." msgstr "从流量方向输出计算流量累积。" -#: src/natcap/invest/routedem.py:68 +#: src/natcap/invest/routedem.py:66 msgid "calculate flow accumulation" msgstr "计算流量累积" -#: src/natcap/invest/routedem.py:73 +#: src/natcap/invest/routedem.py:71 msgid "Calculate streams from the flow accumulation output. " msgstr "从流量累积输出中计算流量。 " -#: src/natcap/invest/routedem.py:75 +#: src/natcap/invest/routedem.py:73 msgid "calculate streams" msgstr "计算流" -#: src/natcap/invest/routedem.py:82 +#: src/natcap/invest/routedem.py:80 msgid "Required if Calculate Streams is selected." msgstr "如果选中“计算流”,则需要。" -#: src/natcap/invest/routedem.py:87 -msgid "Calculate flow distance from each pixel to a stream as defined in the Calculate Streams output." +#: src/natcap/invest/routedem.py:85 +msgid "" +"Calculate flow distance from each pixel to a stream as defined in the " +"Calculate Streams output." msgstr "计算从每个栅格到在计算流输出中定义的流的距离。" -#: src/natcap/invest/routedem.py:90 +#: src/natcap/invest/routedem.py:88 msgid "calculate distance to stream" msgstr "计算到溪流的距离" -#: src/natcap/invest/routedem.py:95 +#: src/natcap/invest/routedem.py:93 msgid "Calculate percent slope from the provided DEM." msgstr "根据所提供的DEM计算坡度百分比。" -#: src/natcap/invest/routedem.py:96 +#: src/natcap/invest/routedem.py:94 msgid "calculate slope" msgstr "计算坡度" -#: src/natcap/invest/scenario_gen_proximity.py:29 -msgid "One or more of \"convert_nearest_to_edge\" or \"convert_farthest_from_edge\" must be selected" +#: src/natcap/invest/routedem.py:99 +#, fuzzy +msgid "Calculate the Strahler Stream order." +msgstr "计算到溪流的距离" + +#: src/natcap/invest/routedem.py:100 +#, fuzzy +msgid "calculate strahler stream orders (D8 only)" +msgstr "计算到溪流的距离" + +#: src/natcap/invest/routedem.py:105 +msgid "Determine subwatersheds from the stream order." +msgstr "" + +#: src/natcap/invest/routedem.py:106 +#, fuzzy +msgid "calculate subwatersheds (D8 only)" +msgstr "计算流" + +#: src/natcap/invest/scenario_gen_proximity.py:28 +msgid "" +"One or more of \"convert_nearest_to_edge\" or " +"\"convert_farthest_from_edge\" must be selected" msgstr "必须选择“convert_nearest_to_edge”或“convert_farthest_from_edge”中的一个或多个" -#: src/natcap/invest/scenario_gen_proximity.py:44 +#: src/natcap/invest/scenario_gen_proximity.py:43 msgid "Base map from which to generate scenarios." msgstr "生成场景的基本映射。" -#: src/natcap/invest/scenario_gen_proximity.py:45 +#: src/natcap/invest/scenario_gen_proximity.py:44 msgid "base LULC map" msgstr "基准LULC图" -#: src/natcap/invest/scenario_gen_proximity.py:49 +#: src/natcap/invest/scenario_gen_proximity.py:48 msgid "The LULC code to which habitat will be converted." msgstr "栖息地要转换为的LULC代码。" -#: src/natcap/invest/scenario_gen_proximity.py:50 +#: src/natcap/invest/scenario_gen_proximity.py:49 msgid "replacement landcover code" msgstr "替换的土地覆盖代码" -#: src/natcap/invest/scenario_gen_proximity.py:56 +#: src/natcap/invest/scenario_gen_proximity.py:55 msgid "Maximum area to be converted to agriculture." msgstr "最大面积转为农业。" -#: src/natcap/invest/scenario_gen_proximity.py:57 +#: src/natcap/invest/scenario_gen_proximity.py:56 msgid "maximum area to convert" msgstr "可转换的最大面积" -#: src/natcap/invest/scenario_gen_proximity.py:62 -msgid "A space-separated list of LULC codes that are used to determine the proximity when referring to 'towards' or 'away' from the base landcover codes" +#: src/natcap/invest/scenario_gen_proximity.py:61 +msgid "" +"A space-separated list of LULC codes that are used to determine the " +"proximity when referring to 'towards' or 'away' from the base landcover " +"codes" msgstr "一个以空格分隔的LULC代码列表,用于在提到“朝向”或“远离”基本地表覆盖代码时确定邻近性" -#: src/natcap/invest/scenario_gen_proximity.py:66 +#: src/natcap/invest/scenario_gen_proximity.py:65 msgid "focal landcover codes" msgstr "焦点土地覆盖代码" -#: src/natcap/invest/scenario_gen_proximity.py:71 -msgid "A space-separated list of LULC codes that can be converted to be converted to agriculture." +#: src/natcap/invest/scenario_gen_proximity.py:70 +msgid "" +"A space-separated list of LULC codes that can be converted to be " +"converted to agriculture." msgstr "一个用空格分隔的LULC代码列表,可以转换为农业代码。" -#: src/natcap/invest/scenario_gen_proximity.py:74 +#: src/natcap/invest/scenario_gen_proximity.py:73 msgid "convertible landcover codes" msgstr "可转换的土地覆盖代码" -#: src/natcap/invest/scenario_gen_proximity.py:80 -msgid "The number of steps that the simulation should take to fragment the habitat of interest in the fragmentation scenario. This parameter is used to divide the conversion simulation into equal subareas of the requested max area. During each sub-step the distance transform is recalculated from the base landcover codes. This can affect the final result if the base types are also convertible types." +#: src/natcap/invest/scenario_gen_proximity.py:79 +msgid "" +"The number of steps that the simulation should take to fragment the " +"habitat of interest in the fragmentation scenario. This parameter is used" +" to divide the conversion simulation into equal subareas of the requested" +" max area. During each sub-step the distance transform is recalculated " +"from the base landcover codes. This can affect the final result if the " +"base types are also convertible types." msgstr "在碎片场景中,模拟将感兴趣的栖息地碎片化所应采取的步骤数。此参数用于将转换模拟划分为所请求的最大区域的相等子区域。在每一个子步骤中,从基本的土地覆盖编码重新计算距离变换。如果基类型也是可转换类型,这可能会影响最终结果。" -#: src/natcap/invest/scenario_gen_proximity.py:88 +#: src/natcap/invest/scenario_gen_proximity.py:87 msgid "number of conversion steps" msgstr "转换步骤数量" -#: src/natcap/invest/scenario_gen_proximity.py:93 -msgid "Area over which to run the conversion. Provide this input if change is only desired in a subregion of the Base LULC map." +#: src/natcap/invest/scenario_gen_proximity.py:92 +msgid "" +"Area over which to run the conversion. Provide this input if change is " +"only desired in a subregion of the Base LULC map." msgstr "运行转换的区域。如果只希望在Base LULC映射的子区域中进行更改,则提供此输入。" -#: src/natcap/invest/scenario_gen_proximity.py:99 -msgid "Convert the 'convertible' landcover codes starting at the furthest pixel from the 'focal' land cover areas and working inwards." +#: src/natcap/invest/scenario_gen_proximity.py:98 +msgid "" +"Convert the 'convertible' landcover codes starting at the furthest pixel " +"from the 'focal' land cover areas and working inwards." msgstr "从距离“焦点”土地覆盖区域最远的像素开始,向内转换“可转换”土地覆盖代码。" -#: src/natcap/invest/scenario_gen_proximity.py:103 +#: src/natcap/invest/scenario_gen_proximity.py:102 msgid "convert farthest from edge" msgstr "从最远的边开始转换" -#: src/natcap/invest/scenario_gen_proximity.py:107 -msgid "Convert the 'convertible' landcover codes starting at the nearest pixels to the 'focal' land cover areas and working outwards." +#: src/natcap/invest/scenario_gen_proximity.py:106 +msgid "" +"Convert the 'convertible' landcover codes starting at the nearest pixels " +"to the 'focal' land cover areas and working outwards." msgstr "将“可转换”土地覆盖代码从最近的像素开始转换为“焦点”土地覆盖区域并向外工作。" -#: src/natcap/invest/scenario_gen_proximity.py:111 +#: src/natcap/invest/scenario_gen_proximity.py:110 msgid "convert nearest to edge" msgstr "最接近边的转换" +#: src/natcap/invest/scenario_gen_proximity.py:115 +msgid "Map of the nearest-to-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:119 +msgid "Map of the farthest-from-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:123 +#: src/natcap/invest/scenario_gen_proximity.py:143 +msgid "" +"Table of land cover classes and the amount of each that was converted for" +" the nearest-to-edge conversion scenario." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:166 +msgid "Copy of the LULC raster masked to the AOI extent." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:171 +msgid "" +"Map of the distance from each pixel to the farthest edge of the focal " +"landcover." +msgstr "" + +#: src/natcap/invest/scenario_gen_proximity.py:177 +msgid "" +"Map of the distance from each pixel to the nearest edge of the focal " +"landcover." +msgstr "" + #: src/natcap/invest/spec_utils.py:12 msgid "workspace" msgstr "工作空间" #: src/natcap/invest/spec_utils.py:13 -msgid "The folder where all the model's output files will be written. If this folder does not exist, it will be created. If data already exists in the folder, it will be overwritten." +msgid "" +"The folder where all the model's output files will be written. If this " +"folder does not exist, it will be created. If data already exists in the " +"folder, it will be overwritten." msgstr "将写入所有模型输出文件的文件夹。如果这个文件夹不存在,将创建它。如果数据已经存在于文件夹中,它将被覆盖。" #: src/natcap/invest/spec_utils.py:24 @@ -1291,7 +1670,9 @@ msgid "file suffix" msgstr "文件后缀" #: src/natcap/invest/spec_utils.py:25 -msgid "Suffix that will be appended to all output file names. Useful to differentiate between model runs." +msgid "" +"Suffix that will be appended to all output file names. Useful to " +"differentiate between model runs." msgstr "后缀,它将附加到所有输出文件名。区分模型运行很有用。" #: src/natcap/invest/spec_utils.py:34 @@ -1299,7 +1680,11 @@ msgid "taskgraph n_workers parameter" msgstr "任务图n_workers参数" #: src/natcap/invest/spec_utils.py:35 -msgid "The n_workers parameter to provide to taskgraph. -1 will cause all jobs to run synchronously. 0 will run all jobs in the same process, but scheduling will take place asynchronously. Any other positive integer will cause that many processes to be spawned to execute tasks." +msgid "" +"The n_workers parameter to provide to taskgraph. -1 will cause all jobs " +"to run synchronously. 0 will run all jobs in the same process, but " +"scheduling will take place asynchronously. Any other positive integer " +"will cause that many processes to be spawned to execute tasks." msgstr "提供给任务图的n_workers参数。-1将使所有作业同步运行。0将运行同一进程中的所有作业,但调度将异步进行。任何其他正整数都将导致生成同样多的进程来执行任务。" #: src/natcap/invest/spec_utils.py:60 @@ -1311,7 +1696,9 @@ msgid "A map of areas over which to aggregate and summarize the final results." msgstr "汇总和总结最终结果的区域地图。" #: src/natcap/invest/spec_utils.py:68 -msgid "Map of land use/land cover codes. Each land use/land cover type must be assigned a unique integer code." +msgid "" +"Map of land use/land cover codes. Each land use/land cover type must be " +"assigned a unique integer code." msgstr "土地利用/土地覆盖代码栅格地图。 每种土地利用/土地覆盖类型必须用一个唯一的整数代码来表示。" #: src/natcap/invest/spec_utils.py:71 @@ -1343,7 +1730,9 @@ msgid "Map of evapotranspiration values." msgstr "蒸发量值地图。" #: src/natcap/invest/spec_utils.py:109 -msgid "Map of soil hydrologic groups. Pixels may have values 1, 2, 3, or 4, corresponding to soil hydrologic groups A, B, C, or D, respectively." +msgid "" +"Map of soil hydrologic groups. Pixels may have values 1, 2, 3, or 4, " +"corresponding to soil hydrologic groups A, B, C, or D, respectively." msgstr "土壤水文组的地图。栅格的值可以是1、2、3或4,分别对应于土壤水文组A、B、C或D。" #: src/natcap/invest/spec_utils.py:112 @@ -1351,7 +1740,9 @@ msgid "soil hydrologic group" msgstr "土壤水文组" #: src/natcap/invest/spec_utils.py:118 -msgid "The number of upslope pixels that must flow into a pixel before it is classified as a stream." +msgid "" +"The number of upslope pixels that must flow into a pixel before it is " +"classified as a stream." msgstr "在被归类为流之前,必须流入一个栅格的上坡栅格的数量。" #: src/natcap/invest/spec_utils.py:121 @@ -1359,328 +1750,597 @@ msgid "threshold flow accumulation" msgstr "阈值流量累积" #: src/natcap/invest/spec_utils.py:125 -#: src/natcap/invest/urban_flood_risk_mitigation.py:63 +#: src/natcap/invest/urban_flood_risk_mitigation.py:64 #, fuzzy msgid "LULC codes from the LULC raster. Each code must be a unique integer." msgstr "来自 LULC 栅格的 LULC 代码。 每个代码必须是唯一的整数。" -#: src/natcap/invest/spec_utils.py:173 -msgid "number of pixels" -msgstr "像元数量" +#: src/natcap/invest/spec_utils.py:141 +msgid "Map of elevation after any pits are filled" +msgstr "" -#: src/natcap/invest/spec_utils.py:174 +#: src/natcap/invest/spec_utils.py:148 #, fuzzy -msgid "currency units" -msgstr "货币单位" +msgid "Map of flow accumulation" +msgstr "阈值流量累积" + +#: src/natcap/invest/spec_utils.py:155 +msgid "" +"MFD flow direction. Note: the pixel values should not be interpreted " +"directly. Each 32-bit number consists of 8 4-bit numbers. Each 4-bit " +"number represents the proportion of flow into one of the eight " +"neighboring pixels." +msgstr "" + +#: src/natcap/invest/spec_utils.py:164 +#, fuzzy +msgid "D8 flow direction." +msgstr "计算流向" + +#: src/natcap/invest/spec_utils.py:169 +msgid "" +"Percent slope, calculated from the pit-filled DEM. 100 is equivalent to a" +" 45 degree slope." +msgstr "" -#: src/natcap/invest/spec_utils.py:183 +#: src/natcap/invest/spec_utils.py:222 +msgid "number of pixels" +msgstr "像元数量" + +#: src/natcap/invest/spec_utils.py:231 #, fuzzy msgid "unitless" msgstr "无单位的" -#: src/natcap/invest/spec_utils.py:254 +#: src/natcap/invest/spec_utils.py:251 +#, fuzzy +msgid "currency units" +msgstr "货币单位" + +#: src/natcap/invest/spec_utils.py:306 msgid "required" msgstr "必填" -#: src/natcap/invest/spec_utils.py:256 +#: src/natcap/invest/spec_utils.py:308 msgid "optional" msgstr "可选的" -#: src/natcap/invest/spec_utils.py:259 +#: src/natcap/invest/spec_utils.py:311 msgid "conditionally required" msgstr "有条件地要求" -#: src/natcap/invest/spec_utils.py:289 +#: src/natcap/invest/spec_utils.py:341 msgid "read" msgstr "阅读" -#: src/natcap/invest/spec_utils.py:291 +#: src/natcap/invest/spec_utils.py:343 msgid "write" msgstr "写入" -#: src/natcap/invest/spec_utils.py:293 +#: src/natcap/invest/spec_utils.py:345 msgid "execute" msgstr "执行" -#: src/natcap/invest/spec_utils.py:366 +#: src/natcap/invest/spec_utils.py:422 msgid "true/false" msgstr "真/假" -#: src/natcap/invest/spec_utils.py:367 +#: src/natcap/invest/spec_utils.py:423 msgid "CSV" msgstr "CSV" -#: src/natcap/invest/spec_utils.py:368 +#: src/natcap/invest/spec_utils.py:424 msgid "directory" msgstr "模型数据目录" -#: src/natcap/invest/spec_utils.py:369 +#: src/natcap/invest/spec_utils.py:425 msgid "file" msgstr "文件后缀" -#: src/natcap/invest/spec_utils.py:370 +#: src/natcap/invest/spec_utils.py:426 msgid "text" msgstr "文本" -#: src/natcap/invest/spec_utils.py:371 +#: src/natcap/invest/spec_utils.py:427 msgid "integer" msgstr "整数" -#: src/natcap/invest/spec_utils.py:372 +#: src/natcap/invest/spec_utils.py:428 msgid "number" msgstr "数量" -#: src/natcap/invest/spec_utils.py:373 +#: src/natcap/invest/spec_utils.py:429 msgid "option" msgstr "选项" -#: src/natcap/invest/spec_utils.py:374 +#: src/natcap/invest/spec_utils.py:430 msgid "percent" msgstr "百分比" -#: src/natcap/invest/spec_utils.py:375 +#: src/natcap/invest/spec_utils.py:431 msgid "raster" msgstr "栅格" -#: src/natcap/invest/spec_utils.py:376 +#: src/natcap/invest/spec_utils.py:432 msgid "ratio" msgstr "比例" -#: src/natcap/invest/spec_utils.py:377 +#: src/natcap/invest/spec_utils.py:433 msgid "vector" msgstr "向量" -#: src/natcap/invest/spec_utils.py:448 +#: src/natcap/invest/spec_utils.py:504 #, fuzzy msgid "units" msgstr "单位" -#: src/natcap/invest/spec_utils.py:476 src/natcap/invest/spec_utils.py:480 +#: src/natcap/invest/spec_utils.py:533 src/natcap/invest/spec_utils.py:537 msgid "Options:" msgstr "选项:" -#: src/natcap/invest/spec_utils.py:484 +#: src/natcap/invest/spec_utils.py:541 msgid " Please see the sample data table for details on the format." msgstr " 关于格式的细节,请参见样本数据表。" -#: src/natcap/invest/stormwater.py:54 -msgid "Event mean concentration of the pollutant in stormwater. You may include any number of these columns for different pollutants, or none at all." +#: src/natcap/invest/stormwater.py:56 +msgid "" +"Event mean concentration of the pollutant in stormwater. You may include " +"any number of these columns for different pollutants, or none at all." msgstr "雨水中污染物的事件平均浓度。你可以为不同的污染物包括任何数量的这些列,或者根本不包括。" -#: src/natcap/invest/stormwater.py:63 +#: src/natcap/invest/stormwater.py:65 msgid "Stormwater runoff coefficient for soil group" msgstr "土壤组的雨水径流系数" -#: src/natcap/invest/stormwater.py:72 +#: src/natcap/invest/stormwater.py:74 msgid "Stormwater percolation coefficient for soil group" msgstr "土壤组的雨水渗漏系数" -#: src/natcap/invest/stormwater.py:82 -msgid "Enter 1 if the LULC class is a connected impervious surface, 0 if not. This column is only used if the 'adjust retention ratios' option is selected. If 'adjust retention ratios' is selected and this column exists, the adjustment algorithm takes into account the LULC as well as road centerlines. If this column does not exist, only the road centerlines are used." -msgstr "如果LULC等级是连接的不透水表面,则输入1,如果不是则输入0。这一栏只有在选择了 \"调整保留率 \"选项时才会使用。如果选择了 \"调整保留率\",并且这一栏存在,调整算法会考虑LULC和道路中心线。如果这一栏不存在,则只使用道路中心线。" +#: src/natcap/invest/stormwater.py:84 +msgid "" +"Enter 1 if the LULC class is a connected impervious surface, 0 if not. " +"This column is only used if the 'adjust retention ratios' option is " +"selected. If 'adjust retention ratios' is selected and this column " +"exists, the adjustment algorithm takes into account the LULC as well as " +"road centerlines. If this column does not exist, only the road " +"centerlines are used." +msgstr "" +"如果LULC等级是连接的不透水表面,则输入1,如果不是则输入0。这一栏只有在选择了 \"调整保留率 \"选项时才会使用。如果选择了 " +"\"调整保留率\",并且这一栏存在,调整算法会考虑LULC和道路中心线。如果这一栏不存在,则只使用道路中心线。" -#: src/natcap/invest/stormwater.py:93 -msgid "Table mapping each LULC code found in the LULC raster to biophysical data about that LULC class. If you provide the percolation coefficient column (PE_[X]) for any soil group, you must provide it for all four soil groups." +#: src/natcap/invest/stormwater.py:95 +msgid "" +"Table mapping each LULC code found in the LULC raster to biophysical data" +" about that LULC class. If you provide the percolation coefficient column" +" (PE_[X]) for any soil group, you must provide it for all four soil " +"groups." msgstr "将LULC栅格中的每个LULC代码与该LULC类别的生物物理数据进行映射的表格。如果你为任何土壤组提供渗滤系数列(PE_[X]),你必须为所有四个土壤组提供。" -#: src/natcap/invest/stormwater.py:98 +#: src/natcap/invest/stormwater.py:100 msgid "Biophysical table" msgstr "生物物理表" -#: src/natcap/invest/stormwater.py:102 -msgid "If true, adjust retention ratios. The adjustment algorithm accounts for drainage effects of nearby impervious surfaces which are directly connected to artifical urban drainage channels (typically roads, parking lots, etc.) Connected impervious surfaces are indicated by the is_connected columnin the biophysical table and/or the road centerlines vector." +#: src/natcap/invest/stormwater.py:104 +msgid "" +"If true, adjust retention ratios. The adjustment algorithm accounts for " +"drainage effects of nearby impervious surfaces which are directly " +"connected to artifical urban drainage channels (typically roads, parking " +"lots, etc.) Connected impervious surfaces are indicated by the " +"is_connected columnin the biophysical table and/or the road centerlines " +"vector." msgstr "如果为真,则调整保留率。调整算法考虑了附近不透水表面的排水影响,这些不透水表面直接与城市人工排水道相连(通常是道路、停车场等)。" -#: src/natcap/invest/stormwater.py:109 +#: src/natcap/invest/stormwater.py:111 msgid "Adjust retention ratios" msgstr "调整保留率" -#: src/natcap/invest/stormwater.py:115 -msgid "Radius around each pixel to adjust retention ratios. Measured in raster coordinate system units. For the adjustment algorithm, a pixel is 'near' a connected impervious surface if its centerpoint is within this radius of connected-impervious LULC and/or a road centerline." -msgstr "每个像素周围的半径,用于调整保留率。以栅格坐标系统单位测量。对于调整算法,如果一个像素的中心点在这个半径内的相连不透水的LULC和/或道路中心线内,则该像素 \"靠近 \"相连不透水的表面。" +#: src/natcap/invest/stormwater.py:117 +msgid "" +"Radius around each pixel to adjust retention ratios. Measured in raster " +"coordinate system units. For the adjustment algorithm, a pixel is 'near' " +"a connected impervious surface if its centerpoint is within this radius " +"of connected-impervious LULC and/or a road centerline." +msgstr "" +"每个像素周围的半径,用于调整保留率。以栅格坐标系统单位测量。对于调整算法,如果一个像素的中心点在这个半径内的相连不透水的LULC和/或道路中心线内,则该像素" +" \"靠近 \"相连不透水的表面。" -#: src/natcap/invest/stormwater.py:121 +#: src/natcap/invest/stormwater.py:123 msgid "Retention radius" msgstr "保留半径" -#: src/natcap/invest/stormwater.py:128 +#: src/natcap/invest/stormwater.py:130 msgid "Map of road centerlines" msgstr "道路中心线地图" -#: src/natcap/invest/stormwater.py:129 +#: src/natcap/invest/stormwater.py:131 msgid "Road centerlines" msgstr "道路中心线" -#: src/natcap/invest/stormwater.py:134 -msgid "Areas over which to aggregate results (typically watersheds or sewersheds). The aggregated data are: average retention ratio and total retention volume; average percolation ratio and total percolation volume if percolation data was provided; total retention value if replacement cost was provided; and total avoided pollutant load for each pollutant provided." +#: src/natcap/invest/stormwater.py:136 +msgid "" +"Areas over which to aggregate results (typically watersheds or " +"sewersheds). The aggregated data are: average retention ratio and total " +"retention volume; average percolation ratio and total percolation volume " +"if percolation data was provided; total retention value if replacement " +"cost was provided; and total avoided pollutant load for each pollutant " +"provided." msgstr "汇总结果的区域(通常是流域或污水流域)。汇总的数据是:平均保留率和总保留量;如果提供了渗滤数据,则提供平均渗滤率和总渗滤量;如果提供了重置成本,则提供总保留价值;以及所提供的每种污染物的总避免污染负荷。" -#: src/natcap/invest/stormwater.py:147 +#: src/natcap/invest/stormwater.py:149 msgid "Replacement cost of stormwater retention devices" msgstr "雨水保留装置的更换费用" -#: src/natcap/invest/stormwater.py:148 +#: src/natcap/invest/stormwater.py:150 msgid "Replacement cost" msgstr "替换费用" -#: src/natcap/invest/urban_cooling_model.py:48 -msgid "Map of LULC for the area of interest. All values in this raster must have corresponding entries in the Biophysical Table." +#: src/natcap/invest/stormwater.py:155 +msgid "" +"Map of the stormwater retention ratio, derived from the LULC raster and " +"biophysical table RC_x columns." +msgstr "" + +#: src/natcap/invest/stormwater.py:162 +msgid "" +"Map of the adjusted retention ratio, calculated according to equation " +"(124) from the ‘retention_ratio, ratio_average, near_road’, and " +"‘near_impervious_lulc’ intermediate outputs." +msgstr "" + +#: src/natcap/invest/stormwater.py:169 +#, fuzzy +msgid "Map of retention volume." +msgstr "蒸发量值地图。" + +#: src/natcap/invest/stormwater.py:177 +msgid "" +"Map of percolation ratio derived by cross-referencing the LULC and soil " +"group rasters with the biophysical table." +msgstr "" + +#: src/natcap/invest/stormwater.py:184 +msgid "Map of percolation (potential aquifer recharge) volume." +msgstr "" + +#: src/natcap/invest/stormwater.py:191 +msgid "" +"Map of the stormwater runoff ratio. This is the inverse of " +"‘retention_ratio.tif’" +msgstr "" + +#: src/natcap/invest/stormwater.py:197 +msgid "Map of runoff volume." +msgstr "" + +#: src/natcap/invest/stormwater.py:205 +msgid "Map of the value of water retained." +msgstr "" + +#: src/natcap/invest/stormwater.py:213 +msgid "" +"Map of aggregate data. This is identical to the aggregate areas input " +"vector, but each polygon is given additional fields with the aggregate " +"data." +msgstr "" + +#: src/natcap/invest/stormwater.py:221 +msgid "Average retention ratio over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:226 +msgid "Total retention volume over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:230 +#, fuzzy +msgid "Average runoff coefficient over this polygon" +msgstr "土壤组的雨水径流系数" + +#: src/natcap/invest/stormwater.py:235 +msgid "Total runoff volume over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:239 +msgid "Average percolation (recharge) ratio over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:244 +msgid "Total volume of potential aquifer recharge over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:249 +msgid "Total avoided (retained) amount of pollutant over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:254 +msgid "Total amount of pollutant in runoff over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:260 +msgid "Total value of the retained volume of water over this polygon" +msgstr "" + +#: src/natcap/invest/stormwater.py:270 +msgid "" +"Copy of the soil group raster input, cropped to the intersection of the " +"three raster inputs." +msgstr "" + +#: src/natcap/invest/stormwater.py:276 +msgid "" +"Copy of the soil group raster input, aligned to the LULC raster and " +"cropped to the intersection of the three raster inputs." +msgstr "" + +#: src/natcap/invest/stormwater.py:283 +msgid "" +"Copy of the precipitation raster input, aligned to the LULC raster and " +"cropped to the intersection of the three raster inputs." +msgstr "" + +#: src/natcap/invest/stormwater.py:295 +msgid "" +"Copy of the road centerlines vector input, reprojected to the LULC raster" +" projection." +msgstr "" + +#: src/natcap/invest/stormwater.py:303 +msgid "" +"A rasterized version of the reprojected centerlines vector, where 1 means" +" the pixel is a road and 0 means it isn’t." +msgstr "" + +#: src/natcap/invest/stormwater.py:310 +msgid "" +"A binary raster derived from the LULC raster and biophysical table " +"is_connected column, where 1 means the pixel has a directly-connected " +"impervious LULC type, and 0 means it does not." +msgstr "" + +#: src/natcap/invest/stormwater.py:318 +msgid "" +"A raster derived from the rasterized centerlines map, where each pixel’s " +"value is its minimum distance to a road pixel (measured centerpoint-to-" +"centerpoint)." +msgstr "" + +#: src/natcap/invest/stormwater.py:328 +msgid "" +"A raster derived from the is_connected_lulc map, where each pixel’s value" +" is its minimum distance to a connected impervious LULC pixel (measured " +"centerpoint-to-centerpoint)." +msgstr "" + +#: src/natcap/invest/stormwater.py:339 +msgid "" +"A binary raster derived from the road_distance map, where 1 means the " +"pixel is within the retention radius of a road pixel, and 0 means it " +"isn’t." +msgstr "" + +#: src/natcap/invest/stormwater.py:346 +msgid "" +"A binary raster derived from the connected_lulc_distance map, where 1 " +"means the pixel is within the retention radius of a connected impervious " +"LULC pixel, and 0 means it isn’t." +msgstr "" + +#: src/natcap/invest/stormwater.py:354 +msgid "" +"A binary raster representing the search kernel that is convolved with the" +" retention_ratio raster to calculate the averaged retention ratio within " +"the retention radius of each pixel." +msgstr "" + +#: src/natcap/invest/stormwater.py:362 +msgid "" +"A raster where each pixel’s value is the average of its neighborhood of " +"pixels in the retention_ratio map, calculated by convolving the search " +"kernel with the retention ratio raster." +msgstr "" + +#: src/natcap/invest/urban_cooling_model.py:49 +msgid "" +"Map of LULC for the area of interest. All values in this raster must have" +" corresponding entries in the Biophysical Table." msgstr "所关注区域的LULC地图。该栅格中的所有数值必须在生物物理表中有相应的条目。" -#: src/natcap/invest/urban_cooling_model.py:66 -msgid "Enter 1 to indicate that the LULC is considered a green area. Enter 0 to indicate that the LULC is not considered a green area." +#: src/natcap/invest/urban_cooling_model.py:68 +msgid "" +"Enter 1 to indicate that the LULC is considered a green area. Enter 0 to " +"indicate that the LULC is not considered a green area." msgstr "输入1表示该LULC被认为是绿色区域。输入 0 表示该 LULC 不被视为绿色区域。" -#: src/natcap/invest/urban_cooling_model.py:73 -msgid "The proportion of area in this LULC class that is covered by tree canopy at least 2 meters high. Required if the 'factors' option is selected for the Cooling Capacity Calculation Method." +#: src/natcap/invest/urban_cooling_model.py:75 +msgid "" +"The proportion of area in this LULC class that is covered by tree canopy " +"at least 2 meters high. Required if the 'factors' option is selected for " +"the Cooling Capacity Calculation Method." msgstr "该LULC等级中被至少2米高的树冠覆盖的面积比例。如果冷却能力计算方法选择 \"因素 \"选项,则需要。" -#: src/natcap/invest/urban_cooling_model.py:81 -msgid "The proportion of solar radiation that is directly reflected by this LULC class. Required if the 'factors' option is selected for the Cooling Capacity Calculation Method." +#: src/natcap/invest/urban_cooling_model.py:83 +msgid "" +"The proportion of solar radiation that is directly reflected by this LULC" +" class. Required if the 'factors' option is selected for the Cooling " +"Capacity Calculation Method." msgstr "该LULC等级直接反射的太阳辐射的比例。如果冷却能力计算方法选择 \"因素 \"选项,则需要。" -#: src/natcap/invest/urban_cooling_model.py:89 -msgid "The ratio of building floor area to footprint area, with all values in this column normalized between 0 and 1. Required if the 'intensity' option is selected for the Cooling Capacity Calculation Method." +#: src/natcap/invest/urban_cooling_model.py:91 +msgid "" +"The ratio of building floor area to footprint area, with all values in " +"this column normalized between 0 and 1. Required if the 'intensity' " +"option is selected for the Cooling Capacity Calculation Method." msgstr "建筑物面积与占地面积的比率,这一栏中的所有数值都在0和1之间归一化。 如果冷却能力计算方法选择了 \"强度 \"选项,则需要。" -#: src/natcap/invest/urban_cooling_model.py:96 -msgid "A table mapping each LULC code to biophysical data for that LULC class. All values in the LULC raster must have corresponding entries in this table." +#: src/natcap/invest/urban_cooling_model.py:98 +msgid "" +"A table mapping each LULC code to biophysical data for that LULC class. " +"All values in the LULC raster must have corresponding entries in this " +"table." msgstr "将每个LULC代码映射到该LULC等级的生物物理数据的表格。LULC栅格中的所有数值必须在此表中有相应的条目。" -#: src/natcap/invest/urban_cooling_model.py:105 +#: src/natcap/invest/urban_cooling_model.py:107 msgid "maximum cooling distance" msgstr "最大冷却距离" -#: src/natcap/invest/urban_cooling_model.py:106 -msgid "Distance over which green areas larger than 2 hectares have a cooling effect." +#: src/natcap/invest/urban_cooling_model.py:108 +msgid "" +"Distance over which green areas larger than 2 hectares have a cooling " +"effect." msgstr "大于2公顷的绿地具有冷却效果的距离。" -#: src/natcap/invest/urban_cooling_model.py:114 +#: src/natcap/invest/urban_cooling_model.py:116 msgid "air blending distance" msgstr "空气混合距离" -#: src/natcap/invest/urban_cooling_model.py:115 +#: src/natcap/invest/urban_cooling_model.py:117 msgid "Radius over which to average air temperatures to account for air mixing." msgstr "平均空气温度的半径,以考虑到空气混合。" -#: src/natcap/invest/urban_cooling_model.py:120 +#: src/natcap/invest/urban_cooling_model.py:122 msgid "reference air temperature" msgstr "参考空气温度" -#: src/natcap/invest/urban_cooling_model.py:123 -msgid "Air temperature in a rural reference area where the urban heat island effect is not observed." +#: src/natcap/invest/urban_cooling_model.py:125 +msgid "" +"Air temperature in a rural reference area where the urban heat island " +"effect is not observed." msgstr "在没有观察到城市热岛效应的农村参考地区的空气温度。" -#: src/natcap/invest/urban_cooling_model.py:128 +#: src/natcap/invest/urban_cooling_model.py:130 msgid "UHI effect" msgstr "城市热岛效应" -#: src/natcap/invest/urban_cooling_model.py:131 -msgid "The magnitude of the urban heat island effect, i.e., the difference between the rural reference temperature and the maximum temperature observed in the city." +#: src/natcap/invest/urban_cooling_model.py:133 +msgid "" +"The magnitude of the urban heat island effect, i.e., the difference " +"between the rural reference temperature and the maximum temperature " +"observed in the city." msgstr "城市热岛效应的大小,即农村参考温度与城市中观察到的最高温度之间的差异。" -#: src/natcap/invest/urban_cooling_model.py:137 +#: src/natcap/invest/urban_cooling_model.py:139 msgid "run energy savings valuation" msgstr "运行能源节约评估" -#: src/natcap/invest/urban_cooling_model.py:139 +#: src/natcap/invest/urban_cooling_model.py:141 msgid "Run the energy savings valuation model." msgstr "运行节能评估模型。" -#: src/natcap/invest/urban_cooling_model.py:142 +#: src/natcap/invest/urban_cooling_model.py:144 msgid "run work productivity valuation" msgstr "运行工作效率评估" -#: src/natcap/invest/urban_cooling_model.py:144 +#: src/natcap/invest/urban_cooling_model.py:146 msgid "Run the work productivity valuation model." msgstr "运行工作生产力评估模型。" -#: src/natcap/invest/urban_cooling_model.py:147 +#: src/natcap/invest/urban_cooling_model.py:149 msgid "average relative humidity" msgstr "平均相对湿度" -#: src/natcap/invest/urban_cooling_model.py:150 -msgid "The average relative humidity over the time period of interest. Required if Run Work Productivity Valuation is selected." +#: src/natcap/invest/urban_cooling_model.py:152 +msgid "" +"The average relative humidity over the time period of interest. Required " +"if Run Work Productivity Valuation is selected." msgstr "所关注的时间段内的平均相对湿度。如果选择了运行工作生产力评估,则需要。" -#: src/natcap/invest/urban_cooling_model.py:156 +#: src/natcap/invest/urban_cooling_model.py:158 msgid "buildings" msgstr "建筑" -#: src/natcap/invest/urban_cooling_model.py:161 -msgid "Code indicating the building type. These codes must match those in the Energy Consumption Table." +#: src/natcap/invest/urban_cooling_model.py:163 +msgid "" +"Code indicating the building type. These codes must match those in the " +"Energy Consumption Table." msgstr "表示建筑类型的代码。这些代码必须与能源消耗表中的代码一致。" -#: src/natcap/invest/urban_cooling_model.py:166 -msgid "A map of built infrastructure footprints. Required if Run Energy Savings Valuation is selected." +#: src/natcap/invest/urban_cooling_model.py:168 +msgid "" +"A map of built infrastructure footprints. Required if Run Energy Savings " +"Valuation is selected." msgstr "已建基础设施足迹的地图。如果选择运行能源节约评估,则需要。" -#: src/natcap/invest/urban_cooling_model.py:171 +#: src/natcap/invest/urban_cooling_model.py:173 msgid "energy consumption table" msgstr "能源消耗表" -#: src/natcap/invest/urban_cooling_model.py:176 +#: src/natcap/invest/urban_cooling_model.py:179 msgid "Building type codes matching those in the Buildings vector." msgstr "建筑物类型代码与建筑物向量中的代码相匹配。" -#: src/natcap/invest/urban_cooling_model.py:183 +#: src/natcap/invest/urban_cooling_model.py:186 msgid "Energy consumption by footprint area for this building type." msgstr "该建筑类型按占地面积计算的能源消耗。" -#: src/natcap/invest/urban_cooling_model.py:191 -msgid "The cost of electricity for this building type. If this column is provided, the energy savings outputs will be in the this currency unit rather than kWh." +#: src/natcap/invest/urban_cooling_model.py:194 +msgid "" +"The cost of electricity for this building type. If this column is " +"provided, the energy savings outputs will be in the this currency unit " +"rather than kWh." msgstr "该建筑类型的电力成本。如果提供了这一栏,节能输出将以货币为单位而非千瓦时为单位。" -#: src/natcap/invest/urban_cooling_model.py:199 -msgid "A table of energy consumption data for each building type. Required if Run Energy Savings Valuation is selected." +#: src/natcap/invest/urban_cooling_model.py:202 +msgid "" +"A table of energy consumption data for each building type. Required if " +"Run Energy Savings Valuation is selected." msgstr "每种建筑类型的能源消耗数据表格。如果选择运行能源节约评估,则需要。" -#: src/natcap/invest/urban_cooling_model.py:204 +#: src/natcap/invest/urban_cooling_model.py:207 msgid "cooling capacity calculation method" msgstr "制冷量计算方法" -#: src/natcap/invest/urban_cooling_model.py:208 +#: src/natcap/invest/urban_cooling_model.py:211 msgid "factors" msgstr "因素" -#: src/natcap/invest/urban_cooling_model.py:209 -msgid "Use the weighted shade, albedo, and ETI factors as a temperature predictor (for daytime temperatures)." +#: src/natcap/invest/urban_cooling_model.py:212 +msgid "" +"Use the weighted shade, albedo, and ETI factors as a temperature " +"predictor (for daytime temperatures)." msgstr "使用加权阴影、反照率和ETI因子作为温度预测器(针对白天的温度)。" -#: src/natcap/invest/urban_cooling_model.py:213 +#: src/natcap/invest/urban_cooling_model.py:216 msgid "intensity" msgstr "强度" -#: src/natcap/invest/urban_cooling_model.py:214 -msgid "Use building intensity as a temperature predictor (for nighttime temperatures)." +#: src/natcap/invest/urban_cooling_model.py:217 +msgid "" +"Use building intensity as a temperature predictor (for nighttime " +"temperatures)." msgstr "使用建筑强度作为温度预测器(针对夜间温度)。" -#: src/natcap/invest/urban_cooling_model.py:218 +#: src/natcap/invest/urban_cooling_model.py:221 msgid "The air temperature predictor method to use." msgstr "要使用的空气温度预测方法。" -#: src/natcap/invest/urban_cooling_model.py:221 +#: src/natcap/invest/urban_cooling_model.py:224 msgid "shade weight" msgstr "阴影权重" -#: src/natcap/invest/urban_cooling_model.py:224 -msgid "The relative weight to apply to shade when calculating the cooling capacity index. If not provided, defaults to 0.6." +#: src/natcap/invest/urban_cooling_model.py:227 +msgid "" +"The relative weight to apply to shade when calculating the cooling " +"capacity index. If not provided, defaults to 0.6." msgstr "计算冷却能力指数时适用于阴凉处的相对权重。如果没有提供,默认为0.6。" -#: src/natcap/invest/urban_cooling_model.py:229 +#: src/natcap/invest/urban_cooling_model.py:232 msgid "albedo weight" msgstr "反照率权重" -#: src/natcap/invest/urban_cooling_model.py:232 -msgid "The relative weight to apply to albedo when calculating the cooling capacity index. If not provided, defaults to 0.2." +#: src/natcap/invest/urban_cooling_model.py:235 +msgid "" +"The relative weight to apply to albedo when calculating the cooling " +"capacity index. If not provided, defaults to 0.2." msgstr "计算冷却能力指数时应用于反照率的相对权重。如果没有提供,默认为0.2。" -#: src/natcap/invest/urban_cooling_model.py:237 +#: src/natcap/invest/urban_cooling_model.py:240 msgid "evapotranspiration weight" msgstr "蒸发权重" -#: src/natcap/invest/urban_cooling_model.py:240 -msgid "The relative weight to apply to ETI when calculating the cooling capacity index. If not provided, defaults to 0.2." +#: src/natcap/invest/urban_cooling_model.py:243 +msgid "" +"The relative weight to apply to ETI when calculating the cooling capacity" +" index. If not provided, defaults to 0.2." msgstr "计算冷却能力指数时,应用于ETI的相对权重。如果没有提供,默认为0.2。" #: src/natcap/invest/urban_flood_risk_mitigation.py:44 @@ -1692,880 +2352,1362 @@ msgid "rainfall depth" msgstr "降雨深度" #: src/natcap/invest/urban_flood_risk_mitigation.py:50 -msgid "Map of LULC. All values in this raster must have corresponding entries in the Biophysical Table." +msgid "" +"Map of LULC. All values in this raster must have corresponding entries in" +" the Biophysical Table." msgstr "LULC的地图。该栅格中的所有数值必须在生物物理表中有相应的条目。" -#: src/natcap/invest/urban_flood_risk_mitigation.py:67 +#: src/natcap/invest/urban_flood_risk_mitigation.py:68 msgid "The curve number value for this LULC type in the soil group code" msgstr "该LULC类型在土壤组代码中的曲线数字值" -#: src/natcap/invest/urban_flood_risk_mitigation.py:72 -msgid "Table of curve number data for each LULC class. All LULC codes in the LULC raster must have corresponding entries in this table for each soil group." +#: src/natcap/invest/urban_flood_risk_mitigation.py:73 +msgid "" +"Table of curve number data for each LULC class. All LULC codes in the " +"LULC raster must have corresponding entries in this table for each soil " +"group." msgstr "每个LULC等级的曲线编号数据表。LULC栅格中的所有LULC代码必须在此表中有每个土壤组的对应条目。" -#: src/natcap/invest/urban_flood_risk_mitigation.py:83 -msgid "Code indicating the building type. These codes must match those in the Damage Loss Table." +#: src/natcap/invest/urban_flood_risk_mitigation.py:84 +msgid "" +"Code indicating the building type. These codes must match those in the " +"Damage Loss Table." msgstr "表示建筑物类型的代码。这些代码必须与损坏损失表中的代码一致。" -#: src/natcap/invest/urban_flood_risk_mitigation.py:89 +#: src/natcap/invest/urban_flood_risk_mitigation.py:90 msgid "Map of building footprints." msgstr "建筑物地图。" -#: src/natcap/invest/urban_flood_risk_mitigation.py:90 +#: src/natcap/invest/urban_flood_risk_mitigation.py:91 msgid "built infrastructure" msgstr "建成的基础设施" -#: src/natcap/invest/urban_flood_risk_mitigation.py:97 +#: src/natcap/invest/urban_flood_risk_mitigation.py:99 msgid "Building type code." msgstr "建筑类型代码。" -#: src/natcap/invest/urban_flood_risk_mitigation.py:101 +#: src/natcap/invest/urban_flood_risk_mitigation.py:103 msgid "Potential damage loss for this building type." msgstr "这种建筑类型的潜在破坏损失。" -#: src/natcap/invest/urban_flood_risk_mitigation.py:104 -msgid "Table of potential damage loss data for each building type. All values in the Built Infrastructure vector 'type' field must have corresponding entries in this table. Required if the Built Infrastructure vector is provided." +#: src/natcap/invest/urban_flood_risk_mitigation.py:106 +msgid "" +"Table of potential damage loss data for each building type. All values in" +" the Built Infrastructure vector 'type' field must have corresponding " +"entries in this table. Required if the Built Infrastructure vector is " +"provided." msgstr "每个建筑类型的潜在破坏损失数据表。基础设施建设矢量 \"类型 \"字段中的所有数值必须在此表中有相应的条目。如果提供建筑基础设施向量,则需要。" -#: src/natcap/invest/urban_flood_risk_mitigation.py:109 +#: src/natcap/invest/urban_flood_risk_mitigation.py:111 msgid "damage loss table" msgstr "危害损失表" -#: src/natcap/invest/validation.py:30 -msgid "Key is missing from the args dict" -msgstr "在args dict中缺少关键信息" +#: src/natcap/invest/urban_nature_access.py:130 +msgid "" +"The proportion of the population within each administrative unit " +"belonging to the identified population group (POP_GROUP). At least one " +"column with the prefix 'pop_' is required when aggregating output by " +"population groups." +msgstr "" -#: src/natcap/invest/validation.py:31 -msgid "Input is required but has no value" -msgstr "输入是必需的,但没有价值" +#: src/natcap/invest/urban_nature_access.py:139 +msgid "" +"A vector representing administrative units. Polygons representing " +"administrative units should not overlap. Overlapping administrative " +"geometries may cause unexpected results and for this reason should not " +"overlap." +msgstr "" -#: src/natcap/invest/validation.py:32 -msgid "Expected the {header} \"{header_name}\" but did not find it" -msgstr "期待{header}\"{header_name}\",但没有找到" +#: src/natcap/invest/urban_nature_access.py:151 +msgid "" +"The amount of urban nature that each resident should have access to. This" +" is often defined by local urban planning documents." +msgstr "" -#: src/natcap/invest/validation.py:34 -msgid "Expected the {header} \"{header_name}\" only once but found it {number} times" -msgstr "预计{header}\"{header_name}\"只有一次,但发现它有{number}次" +#: src/natcap/invest/urban_nature_access.py:163 +msgid "" +"All pixels within the search radius contribute equally to an urban nature" +" pixel." +msgstr "" -#: src/natcap/invest/validation.py:36 -msgid "Value \"{value}\" could not be interpreted as a number" -msgstr "值\"{value}\"不能被解释为一个数字" +#: src/natcap/invest/urban_nature_access.py:169 +msgid "" +"Contributions to an urban nature pixel decrease exponentially, where " +"\"weight = e^(-pixel_dist / search_radius)\"" +msgstr "" -#: src/natcap/invest/validation.py:37 -msgid "Layer must be projected in this unit: \"{unit_a}\" but found this unit: \"{unit_b}\"" -msgstr "层必须投射在这个单位。\"{unit_a}\"但发现这个单位是\"{unit_b}\"" +#: src/natcap/invest/urban_nature_access.py:176 +msgid "" +"Contributions to an urban nature pixel decrease according to a normal " +"(\"gaussian\") distribution with a sigma of 3." +msgstr "" -#: src/natcap/invest/validation.py:39 -msgid "An unexpected error occurred in validation" -msgstr "在验证过程中发生了一个意外的错误" +#: src/natcap/invest/urban_nature_access.py:183 +msgid "" +"Contributions to an urban nature pixel decrease faster as distances " +"approach the search radius. Weights are calculated by \"weight = 0.75 * " +"(1-(pixel_dist / search_radius)^2)\"" +msgstr "" -#: src/natcap/invest/validation.py:40 -msgid "Directory not found" -msgstr "未找到目录" +#: src/natcap/invest/urban_nature_access.py:210 +msgid "The type of search radius to use." +msgstr "" -#: src/natcap/invest/validation.py:41 -msgid "Path must be a directory" -msgstr "路径必须是一个目录" +#: src/natcap/invest/urban_nature_access.py:216 +msgid "The search radius is the same for all types of urban nature." +msgstr "" -#: src/natcap/invest/validation.py:42 -msgid "File not found" -msgstr "未找到文件" +#: src/natcap/invest/urban_nature_access.py:222 +msgid "" +"The search radius is defined for each distinct urban nature LULC " +"classification." +msgstr "" -#: src/natcap/invest/validation.py:43 -msgid "Dataset must have a valid projection." -msgstr "数据集必须有一个有效的投影。" +#: src/natcap/invest/urban_nature_access.py:228 +msgid "The search radius is defined for each distinct population group." +msgstr "" -#: src/natcap/invest/validation.py:44 -msgid "Dataset must be projected in linear units." -msgstr "数据集必须以线性单位投影。" +#: src/natcap/invest/urban_nature_access.py:238 +msgid "" +"Whether to aggregate statistics by population group within each " +"administrative unit. If selected, population groups will be read from the" +" fields of the user-defined administrative boundaries vector. This option" +" is implied if the search radii are defined by population groups." +msgstr "" -#: src/natcap/invest/validation.py:45 -msgid "File could not be opened as a GDAL raster" -msgstr "文件无法以GDAL栅格形式打开" +#: src/natcap/invest/urban_nature_access.py:252 +msgid "" +"The search radius to use when running the model under a uniform search " +"radius. Required when running the model with a uniform search radius. " +"Units are in meters." +msgstr "" -#: src/natcap/invest/validation.py:46 -msgid "File found to be an overview \".ovr\" file." -msgstr "发现文件是一个概览\".ovr \"文件。" +#: src/natcap/invest/urban_nature_access.py:266 +msgid "" +"The name of the population group. Names must match the names defined in " +"the administrative boundaries vector." +msgstr "" -#: src/natcap/invest/validation.py:47 -msgid "File could not be opened as a GDAL vector" -msgstr "文件无法作为GDAL向量打开" +#: src/natcap/invest/urban_nature_access.py:276 +msgid "" +"The search radius in meters to use for this population group. Values " +"must be >= 0." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:282 +msgid "" +"A table associating population groups with the distance in meters that " +"members of the population group will, on average, travel to find urban " +"nature. Required when running the model with search radii defined per " +"population group." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:418 +msgid "" +"Positive pixel values indicate an oversupply of urban nature for the " +"population group POP_GROUP relative to the stated urban nature demand. " +"Negative values indicate an undersupply of urban nature for the " +"population group POP_GROUP relative to the stated urban nature demand." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:432 +msgid "" +"The area of greenspace available within the defined radius, weighted by " +"the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:442 +msgid "" +"The area of greenspace available within the radius associated with urban " +"nature class LUCODE, weighted by the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:453 +msgid "" +"The area of greenspace available within the radius associated with group " +"POP_GROUP, weighted by the selected decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:467 +msgid "" +"A copy of the user's land use land cover raster. If the user-supplied " +"LULC has non-square pixels, they will be resampled to square pixels in " +"this raster." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:475 +msgid "" +"The user's population raster, aligned to the same resolution and " +"dimensions as the aligned LULC." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:481 +msgid "The population experiencing an urban nature deficit." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:487 +msgid "The population experiencing an urban nature surplus." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:495 +msgid "" +"A sum of the population within the given search radius SEARCH_RADIUS, " +"weighted by the user's decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:505 +msgid "The area of urban nature (in square meters) represented in each pixel." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:514 +msgid "The calculated urban nature/population ratio." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:523 +msgid "" +"Pixel values represent the ares of urban nature (in square meters) " +"represented in each pixel for the urban nature class represented by the " +"land use land cover code LUCODE." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:533 +msgid "" +"The urban nature supplied to populations due to the land use land cover " +"code LUCODE" +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:541 +msgid "" +"The calculated urban nature/population ratio for the urban nature class " +"represented by the land use land cover code LUCODE." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:552 +msgid "" +"Each pixel represents the population of a pixel belonging to the " +"population in the population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:561 +msgid "" +"Each pixel represents the proportion of the total population that belongs" +" to the population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:570 +msgid "" +"Each pixel represents the total number of people within the search radius" +" for the population group POP_GROUP, weighted by the user's selection of " +"decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:580 +msgid "The total population, weighted by the appropriate decay function." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:588 +msgid "The urban nature supply per capita to population group POP_GROUP." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:596 +msgid "" +"The population in population group POP_GROUP that are experiencing an " +"urban nature deficit." +msgstr "" + +#: src/natcap/invest/urban_nature_access.py:604 +msgid "" +"The population in population group POP_GROUP that are experiencing an " +"urban nature surplus." +msgstr "" + +#: src/natcap/invest/validation.py:33 +msgid "Key is missing from the args dict" +msgstr "在args dict中缺少关键信息" + +#: src/natcap/invest/validation.py:34 +msgid "Input is required but has no value" +msgstr "输入是必需的,但没有价值" + +#: src/natcap/invest/validation.py:35 +msgid "Expected the {header} \"{header_name}\" but did not find it" +msgstr "期待{header}\"{header_name}\",但没有找到" + +#: src/natcap/invest/validation.py:37 +#, fuzzy +msgid "" +"Expected to find at least one {header} matching the pattern " +"\"{header_name}\" but found none" +msgstr "期待{header}\"{header_name}\",但没有找到" + +#: src/natcap/invest/validation.py:40 +msgid "" +"Expected the {header} \"{header_name}\" only once but found it {number} " +"times" +msgstr "预计{header}\"{header_name}\"只有一次,但发现它有{number}次" + +#: src/natcap/invest/validation.py:43 +msgid "Value \"{value}\" could not be interpreted as a number" +msgstr "值\"{value}\"不能被解释为一个数字" + +#: src/natcap/invest/validation.py:45 +msgid "" +"Layer must be projected in this unit: \"{unit_a}\" but found this unit: " +"\"{unit_b}\"" +msgstr "层必须投射在这个单位。\"{unit_a}\"但发现这个单位是\"{unit_b}\"" #: src/natcap/invest/validation.py:48 -msgid "File could not be opened as a CSV or Excel file." -msgstr "文件无法作为CSV或Excel文件打开。" +msgid "An unexpected error occurred in validation" +msgstr "在验证过程中发生了一个意外的错误" #: src/natcap/invest/validation.py:49 -msgid "File could not be opened as a CSV. File must be encoded as a UTF-8 CSV." -msgstr "文件不能以CSV形式打开。文件必须被编码为UTF-8 CSV。" +msgid "Directory not found" +msgstr "未找到目录" + +#: src/natcap/invest/validation.py:50 +msgid "Path must be a directory" +msgstr "路径必须是一个目录" #: src/natcap/invest/validation.py:51 +msgid "File not found" +msgstr "未找到文件" + +#: src/natcap/invest/validation.py:52 +msgid "Dataset must have a valid projection." +msgstr "数据集必须有一个有效的投影。" + +#: src/natcap/invest/validation.py:53 +msgid "Dataset must be projected in linear units." +msgstr "数据集必须以线性单位投影。" + +#: src/natcap/invest/validation.py:54 +msgid "File could not be opened as a GDAL raster" +msgstr "文件无法以GDAL栅格形式打开" + +#: src/natcap/invest/validation.py:55 +msgid "File found to be an overview \".ovr\" file." +msgstr "发现文件是一个概览\".ovr \"文件。" + +#: src/natcap/invest/validation.py:56 +msgid "File could not be opened as a GDAL vector" +msgstr "文件无法作为GDAL向量打开" + +#: src/natcap/invest/validation.py:57 msgid "Value did not match expected pattern {regexp}" msgstr "值不符合预期模式 {regexp}" -#: src/natcap/invest/validation.py:52 +#: src/natcap/invest/validation.py:59 msgid "Value must be one of: {option_list}" msgstr "值必须是以下之一。{option_list}" -#: src/natcap/invest/validation.py:53 +#: src/natcap/invest/validation.py:60 msgid "Value does not meet condition {condition}" msgstr "值不符合条件 {condition}" -#: src/natcap/invest/validation.py:54 +#: src/natcap/invest/validation.py:61 msgid "Value {value} is not in the range {range}" msgstr "值{value}不在范围内{range}。" -#: src/natcap/invest/validation.py:55 +#: src/natcap/invest/validation.py:62 msgid "Value \"{value}\" does not represent an integer" msgstr "值\"{value}\"不代表一个整数" -#: src/natcap/invest/validation.py:56 +#: src/natcap/invest/validation.py:63 msgid "Value must be either True or False, not {value}" msgstr "值必须是真或假,而不是{value}。" -#: src/natcap/invest/validation.py:57 +#: src/natcap/invest/validation.py:64 msgid "Spatial file {filepath} has no projection" msgstr "空间文件{filepath}没有投影" -#: src/natcap/invest/validation.py:58 -msgid "Bounding boxes do not intersect: {bboxes}" -msgstr "边界不相交:{bboxes} 。" +#: src/natcap/invest/validation.py:65 +msgid "" +"Not all of the spatial layers overlap each other. All bounding boxes must" +" intersect: {bboxes}" +msgstr "" -#: src/natcap/invest/validation.py:59 +#: src/natcap/invest/validation.py:68 msgid "You must have {permission} access to this file" msgstr "你必须有{permission}的权限来访问这个文件" -#: src/natcap/invest/wave_energy.py:45 +#: src/natcap/invest/validation.py:70 +msgid "Geometry type must be one of {allowed}" +msgstr "" + +#: src/natcap/invest/wave_energy.py:34 +msgid "Index of this percentile bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:38 +msgid "Percentile range within this bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:42 +msgid "Number of pixels whose wave energy values fall into this percentile bin." +msgstr "" + +#: src/natcap/invest/wave_energy.py:51 src/natcap/invest/wind_energy.py:331 +msgid "Unique identifier for each point." +msgstr "每个点的唯一标识符。" + +#: src/natcap/invest/wave_energy.py:55 src/natcap/invest/wind_energy.py:335 +msgid "This is a land connection point" +msgstr "这是一个陆地连接点" + +#: src/natcap/invest/wave_energy.py:57 src/natcap/invest/wind_energy.py:337 +msgid "This is a grid connection point" +msgstr "这是一个电网连接点" + +#: src/natcap/invest/wave_energy.py:60 src/natcap/invest/wind_energy.py:340 +msgid "The type of connection at this point." +msgstr "这时的连接类型。" + +#: src/natcap/invest/wave_energy.py:65 src/natcap/invest/wind_energy.py:345 +msgid "Latitude of the connection point." +msgstr "连接点的纬度。" + +#: src/natcap/invest/wave_energy.py:70 src/natcap/invest/wind_energy.py:350 +msgid "Longitude of the connection point." +msgstr "连接点的经度。" + +#: src/natcap/invest/wave_energy.py:74 +msgid "Name for the connection point location." +msgstr "连接点位置的名称。" + +#: src/natcap/invest/wave_energy.py:149 msgid "Point vector for the west coast of North America and Hawaii." msgstr "北美洲西海岸和夏威夷的点矢量。" -#: src/natcap/invest/wave_energy.py:52 +#: src/natcap/invest/wave_energy.py:156 msgid "Extract vector for the west coast of North America and Hawaii." msgstr "为北美西海岸和夏威夷提取矢量。" -#: src/natcap/invest/wave_energy.py:57 +#: src/natcap/invest/wave_energy.py:161 msgid "WaveWatchIII data for the west coast of North America and Hawaii." msgstr "北美西海岸和夏威夷的WaveWatchIII数据。" -#: src/natcap/invest/wave_energy.py:64 +#: src/natcap/invest/wave_energy.py:168 msgid "Point vector for the East Coast of North America and Puerto Rico." msgstr "北美东海岸和波多黎各的点矢量。" -#: src/natcap/invest/wave_energy.py:71 +#: src/natcap/invest/wave_energy.py:175 msgid "Extract vector for the East Coast of North America and Puerto Rico." msgstr "北美东海岸和波多黎各的提取矢量。" -#: src/natcap/invest/wave_energy.py:76 +#: src/natcap/invest/wave_energy.py:180 msgid "WaveWatchIII data for the East Coast of North America and Puerto Rico." msgstr "北美东海岸和波多黎各的WaveWatchIII数据。" -#: src/natcap/invest/wave_energy.py:83 +#: src/natcap/invest/wave_energy.py:187 msgid "Point vector for the North Sea 4 meter resolution." msgstr "北海的点向量,4米分辨率。" -#: src/natcap/invest/wave_energy.py:89 +#: src/natcap/invest/wave_energy.py:193 msgid "Extract vector for the North Sea 4 meter resolution." msgstr "北海4米分辨率的提取矢量。" -#: src/natcap/invest/wave_energy.py:93 +#: src/natcap/invest/wave_energy.py:197 msgid "WaveWatchIII data for the North Sea 4 meter resolution." msgstr "北海4米分辨率的WaveWatchIII数据。" -#: src/natcap/invest/wave_energy.py:100 +#: src/natcap/invest/wave_energy.py:204 msgid "Point vector for the North Sea 10 meter resolution." msgstr "北海10米分辨率的点矢量。" -#: src/natcap/invest/wave_energy.py:106 +#: src/natcap/invest/wave_energy.py:210 msgid "Extract vector for the North Sea 10 meter resolution." msgstr "北海10米分辨率的提取矢量。" -#: src/natcap/invest/wave_energy.py:110 +#: src/natcap/invest/wave_energy.py:214 msgid "WaveWatchIII data for the North Sea 10 meter resolution." msgstr "北海10米分辨率的WaveWatchIII数据。" -#: src/natcap/invest/wave_energy.py:117 +#: src/natcap/invest/wave_energy.py:221 msgid "Point vector for Australia." msgstr "澳大利亚的点矢量。" -#: src/natcap/invest/wave_energy.py:122 +#: src/natcap/invest/wave_energy.py:226 msgid "Extract vector for Australia." msgstr "为澳大利亚提取矢量。" -#: src/natcap/invest/wave_energy.py:125 +#: src/natcap/invest/wave_energy.py:229 msgid "WaveWatchIII data for Australia." msgstr "澳大利亚的WaveWatchIII数据。" -#: src/natcap/invest/wave_energy.py:130 +#: src/natcap/invest/wave_energy.py:234 msgid "Global point vector." msgstr "全局点矢量。" -#: src/natcap/invest/wave_energy.py:135 +#: src/natcap/invest/wave_energy.py:239 msgid "Global extract vector." msgstr "全球提取矢量。" -#: src/natcap/invest/wave_energy.py:138 +#: src/natcap/invest/wave_energy.py:242 msgid "Global WaveWatchIII data." msgstr "全球WaveWatchIII数据。" -#: src/natcap/invest/wave_energy.py:140 -msgid "Pre-packaged wave energy data directory. This is provided with the sample data." +#: src/natcap/invest/wave_energy.py:244 +msgid "" +"Pre-packaged wave energy data directory. This is provided with the sample" +" data." msgstr "预先打包的波浪能数据目录。这是与样本数据一起提供的。" -#: src/natcap/invest/wave_energy.py:143 +#: src/natcap/invest/wave_energy.py:247 msgid "wave base data" msgstr "波段基础数据" -#: src/natcap/invest/wave_energy.py:148 +#: src/natcap/invest/wave_energy.py:252 msgid "West Coast of North America and Hawaii" msgstr "北美洲西海岸和夏威夷" -#: src/natcap/invest/wave_energy.py:150 +#: src/natcap/invest/wave_energy.py:254 msgid "East Coast of North America and Puerto Rico" msgstr "北美洲东海岸和波多黎各" -#: src/natcap/invest/wave_energy.py:153 +#: src/natcap/invest/wave_energy.py:257 msgid "North Sea 4 meter resolution" msgstr "北海4米分辨率" -#: src/natcap/invest/wave_energy.py:155 +#: src/natcap/invest/wave_energy.py:259 msgid "North Sea 10 meter resolution" msgstr "北海10米分辨率" -#: src/natcap/invest/wave_energy.py:156 +#: src/natcap/invest/wave_energy.py:260 msgid "Australia" msgstr "澳大利亚" -#: src/natcap/invest/wave_energy.py:157 +#: src/natcap/invest/wave_energy.py:261 msgid "Global" msgstr "全球" -#: src/natcap/invest/wave_energy.py:159 +#: src/natcap/invest/wave_energy.py:263 msgid "The analysis area over which to run the model." msgstr "运行模型的研究区域。" -#: src/natcap/invest/wave_energy.py:161 +#: src/natcap/invest/wave_energy.py:265 msgid "analysis area" msgstr "研究区" -#: src/natcap/invest/wave_energy.py:171 -msgid "A matrix of the wave machine performance, or ability to capture wave energy, in different sea state conditions. The first column contains wave height values (in meters, increasing from top to bottom), and the first row contains wave period values (in seconds, increasing from left to right). Values within the matrix are the machine performance in kilowatts at that sea state condition, described by the wave height (row) and wave period (column). The model linearly interpolates sea state data from the base wave dataset onto this matrix to determine performance." +#: src/natcap/invest/wave_energy.py:275 +msgid "" +"A matrix of the wave machine performance, or ability to capture wave " +"energy, in different sea state conditions. The first column contains wave" +" height values (in meters, increasing from top to bottom), and the first " +"row contains wave period values (in seconds, increasing from left to " +"right). Values within the matrix are the machine performance in kilowatts" +" at that sea state condition, described by the wave height (row) and wave" +" period (column). The model linearly interpolates sea state data from the" +" base wave dataset onto this matrix to determine performance." msgstr "波浪机在不同海况条件下的性能,或捕捉波浪能量的能力的矩阵。第一列包含波高值(米,从上到下增加),第一行包含波周期值(秒,从左到右增加)。矩阵内的数值是在该海况下的机器性能,单位是千瓦,由波高(行)和波期(列)描述。该模型将基本波浪数据集的海况数据线性内插到该矩阵上,以确定性能。" -#: src/natcap/invest/wave_energy.py:182 +#: src/natcap/invest/wave_energy.py:286 msgid "machine performance table" msgstr "机器性能表" -#: src/natcap/invest/wave_energy.py:188 -msgid "Maximum capacity for device." -msgstr "设备的最大容量。" - -#: src/natcap/invest/wave_energy.py:193 -msgid "Upper limit of wave height for device operation. The device shuts down when waves are higher than this." -msgstr "设备运行的波浪高度的上限。当波浪高于这个高度时,设备就会关闭。" +#: src/natcap/invest/wave_energy.py:295 +msgid "" +"Name of the machine parameter. Expected parameters are: 'capmax' (maximum" +" capacity for device, in kilowatts), 'hsmax' (upper limit of wave height " +"for device operation, in meters), and 'tpmax' (upper limit of wave period" +" for device operation, in seconds)." +msgstr "" -#: src/natcap/invest/wave_energy.py:200 -msgid "Upper limit of wave period for device operation. The device shuts down when the wave period is longer than this." -msgstr "设备运行的波形周期的上限。当波浪周期长于此值时,设备就会关闭。" +#: src/natcap/invest/wave_energy.py:305 src/natcap/invest/wave_energy.py:354 +#, fuzzy +msgid "Value of the machine parameter." +msgstr "机器参数表" -#: src/natcap/invest/wave_energy.py:208 +#: src/natcap/invest/wave_energy.py:308 msgid "Table of parameters for the wave energy machine in use." msgstr "使用中的波浪能机的参数表。" -#: src/natcap/invest/wave_energy.py:209 +#: src/natcap/invest/wave_energy.py:309 msgid "machine parameter table" msgstr "机器参数表" -#: src/natcap/invest/wave_energy.py:212 src/natcap/invest/wind_energy.py:100 +#: src/natcap/invest/wave_energy.py:312 src/natcap/invest/wind_energy.py:128 msgid "bathymetry" msgstr "测深学" -#: src/natcap/invest/wave_energy.py:215 src/natcap/invest/wind_energy.py:99 +#: src/natcap/invest/wave_energy.py:315 src/natcap/invest/wind_energy.py:127 msgid "Map of ocean depth. Values should be negative." msgstr "海洋深度的地图。数值应该是负的。" -#: src/natcap/invest/scenic_quality/scenic_quality.py:122 -#: src/natcap/invest/wave_energy.py:220 +#: src/natcap/invest/scenic_quality/scenic_quality.py:121 +#: src/natcap/invest/wave_energy.py:320 msgid "Run the valuation model." msgstr "运行估值模型。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:348 -#: src/natcap/invest/scenic_quality/scenic_quality.py:119 -#: src/natcap/invest/wave_energy.py:221 src/natcap/invest/wind_energy.py:282 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:353 +#: src/natcap/invest/scenic_quality/scenic_quality.py:118 +#: src/natcap/invest/wave_energy.py:321 src/natcap/invest/wind_energy.py:310 msgid "run valuation" msgstr "运行估值模型" -#: src/natcap/invest/wave_energy.py:228 src/natcap/invest/wind_energy.py:302 -msgid "Unique identifier for each point." -msgstr "每个点的唯一标识符。" - -#: src/natcap/invest/wave_energy.py:232 src/natcap/invest/wind_energy.py:306 -msgid "This is a land connection point" -msgstr "这是一个陆地连接点" +#: src/natcap/invest/wave_energy.py:327 +msgid "" +"A table of data for each connection point. Required if Run Valuation is " +"selected." +msgstr "每个连接点的数据表格。如果选择运行估值,则需要。" -#: src/natcap/invest/wave_energy.py:234 src/natcap/invest/wind_energy.py:308 -msgid "This is a grid connection point" -msgstr "这是一个电网连接点" +#: src/natcap/invest/wave_energy.py:330 +msgid "grid connection points table" +msgstr "电网连接点表" -#: src/natcap/invest/wave_energy.py:237 src/natcap/invest/wind_energy.py:311 -msgid "The type of connection at this point." -msgstr "这时的连接类型。" +#: src/natcap/invest/wave_energy.py:339 +msgid "" +"Name of the machine parameter. Expected parameters are: 'capmax' (maximum" +" capacity for device, in kilowatts), 'cc' (capital cost per device " +"installed, $/kilowatt), 'cml' (cost of mooring lines, $/kilometer), 'cul'" +" (cost of underwater cable, $/kilometer), 'col' (cost of overland " +"transmission lines, $/kilometer), 'omc' (operating and maintenance cost, " +"$/kilowatt hour), 'p' (price of electricity, $/kilowatt hour), 'r' " +"(discount rate, between 0 and 1), 'smlpm' (number of slack lines required" +" per machine)" +msgstr "" -#: src/natcap/invest/wave_energy.py:242 src/natcap/invest/wind_energy.py:316 -msgid "Latitude of the connection point." -msgstr "连接点的纬度。" +#: src/natcap/invest/wave_energy.py:358 +msgid "" +"Table of economic parameters for the wave energy machine. Required if Run" +" Valuation is selected." +msgstr "波浪能机器的经济参数表。如果选择运行评估,则需要。" -#: src/natcap/invest/wave_energy.py:247 src/natcap/invest/wind_energy.py:321 -msgid "Longitude of the connection point." -msgstr "连接点的经度。" +#: src/natcap/invest/wave_energy.py:361 +msgid "machine economic table" +msgstr "机器经济表" -#: src/natcap/invest/wave_energy.py:251 -msgid "Name for the connection point location." -msgstr "连接点位置的名称。" +#: src/natcap/invest/wave_energy.py:368 +msgid "Number of wave machines to model. Required if Run Valuation is selected." +msgstr "要建模的波浪机数量。如果选择运行估价,则需要。" -#: src/natcap/invest/wave_energy.py:255 -msgid "A table of data for each connection point. Required if Run Valuation is selected." -msgstr "每个连接点的数据表格。如果选择运行估值,则需要。" +#: src/natcap/invest/wave_energy.py:371 +msgid "number of machines" +msgstr "机器数量" -#: src/natcap/invest/wave_energy.py:258 -msgid "grid connection points table" -msgstr "电网连接点表" +#: src/natcap/invest/wave_energy.py:379 +msgid "Map of captured wave energy per WEC device." +msgstr "" -#: src/natcap/invest/wave_energy.py:266 -msgid "Maximum capacity of the device." -msgstr "设备的最大容量。" +#: src/natcap/invest/wave_energy.py:387 +msgid "" +"Map of captured wave energy per WEC device reclassified by quantiles (1 =" +" < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +msgstr "" -#: src/natcap/invest/wave_energy.py:271 -msgid "Capital cost per device installed." -msgstr "每套设备的资本成本。" +#: src/natcap/invest/wave_energy.py:394 +msgid "" +"Table of value ranges for each captured wave energy quantile group as " +"well as the number of pixels for each group." +msgstr "" -#: src/natcap/invest/wave_energy.py:276 -msgid "Cost of mooring lines." -msgstr "停泊线的费用。" +#: src/natcap/invest/wave_energy.py:404 +msgid "Range of wave energy values within this percentile bin." +msgstr "" -#: src/natcap/invest/wave_energy.py:281 -msgid "Cost of underwater cable." -msgstr "水下电缆的成本。" +#: src/natcap/invest/wave_energy.py:412 +msgid "Vector map of the provided grid points" +msgstr "" -#: src/natcap/invest/wave_energy.py:286 -msgid "Cost of overland transmission lines." -msgstr "陆上输电线路的成本。" +#: src/natcap/invest/wave_energy.py:418 +msgid "Vector map of the provided land points" +msgstr "" -#: src/natcap/invest/wave_energy.py:291 -msgid "Operating and maintenance cost." -msgstr "运营和维护成本。" +#: src/natcap/invest/wave_energy.py:423 +msgid "" +"Map of positive values of net present value over the 25-year lifespan of " +"a wave energy facility, reclassified by quantiles (1 = < 25%, 2 = 25-50%," +" 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +msgstr "" -#: src/natcap/invest/wave_energy.py:296 -msgid "Price of electricity." -msgstr "电价。" +#: src/natcap/invest/wave_energy.py:431 +msgid "" +"Table of value ranges for each net present value quantile group as well " +"as the number of pixels for each group." +msgstr "" -#: src/natcap/invest/wave_energy.py:300 -msgid "Discount rate." -msgstr "折扣率。" +#: src/natcap/invest/wave_energy.py:441 +msgid "Range of net present values within this percentile bin." +msgstr "" -#: src/natcap/invest/wave_energy.py:305 -msgid "Number of slack lines required per machine." -msgstr "每台机器需要的松弛线的数量。" +#: src/natcap/invest/wave_energy.py:448 +msgid "" +"Map of net present value over the 25-year lifespan of a wave energy " +"facility." +msgstr "" -#: src/natcap/invest/wave_energy.py:310 -msgid "Table of economic parameters for the wave energy machine. Required if Run Valuation is selected." -msgstr "波浪能机器的经济参数表。如果选择运行评估,则需要。" +#: src/natcap/invest/wave_energy.py:457 +msgid "Map of potential wave power." +msgstr "" -#: src/natcap/invest/wave_energy.py:313 -msgid "machine economic table" -msgstr "机器经济表" +#: src/natcap/invest/wave_energy.py:464 +msgid "" +"Map of potential wave power classified into quantiles (1 = < 25%, 2 = " +"25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +msgstr "" -#: src/natcap/invest/wave_energy.py:320 -msgid "Number of wave machines to model. Required if Run Valuation is selected." -msgstr "要建模的波浪机数量。如果选择运行估价,则需要。" +#: src/natcap/invest/wave_energy.py:471 +msgid "" +"Table of value ranges for each wave power quantile group as well as the " +"number of pixels for each group." +msgstr "" -#: src/natcap/invest/wave_energy.py:323 -msgid "number of machines" -msgstr "机器数量" +#: src/natcap/invest/wave_energy.py:480 +msgid "Range of potential wave power values within this percentile bin." +msgstr "" -#: src/natcap/invest/wind_energy.py:55 +#: src/natcap/invest/wind_energy.py:36 msgid "Longitude of the data point." msgstr "数据点的经度。" -#: src/natcap/invest/wind_energy.py:60 +#: src/natcap/invest/wind_energy.py:41 msgid "Latitude of the data point." msgstr "数据点的纬度。" -#: src/natcap/invest/wind_energy.py:65 +#: src/natcap/invest/wind_energy.py:46 src/natcap/invest/wind_energy.py:76 msgid "Weibull scale factor at the reference hub height at this point." msgstr "在这一点上,参考枢纽高度的Weibull比例因子。" -#: src/natcap/invest/wind_energy.py:72 +#: src/natcap/invest/wind_energy.py:53 msgid "Weibull shape factor at this point." msgstr "在这一点上,Weibull形状因子。" -#: src/natcap/invest/wind_energy.py:77 -msgid "The reference hub height at this point, at which wind speed data was collected and LAM was estimated." +#: src/natcap/invest/wind_energy.py:58 +msgid "" +"The reference hub height at this point, at which wind speed data was " +"collected and LAM was estimated." msgstr "在这一点上的参考枢纽高度,在这一点上收集风速数据并估计LAM。" -#: src/natcap/invest/wind_energy.py:82 +#: src/natcap/invest/wind_energy.py:69 +#, fuzzy +msgid "Weibull scale factor calculated for the proposed hub height at this point." +msgstr "在这一点上,参考枢纽高度的Weibull比例因子。" + +#: src/natcap/invest/wind_energy.py:83 +#, fuzzy +msgid "Power density at this point." +msgstr "在这一点上,Weibull形状因子。" + +#: src/natcap/invest/wind_energy.py:88 +msgid "Predicted energy harvested from a wind farm centered on this point." +msgstr "" + +#: src/natcap/invest/wind_energy.py:110 msgid "Table of Weibull parameters for each wind data point." msgstr "每个风数据点的Weibull参数表。" -#: src/natcap/invest/wind_energy.py:83 +#: src/natcap/invest/wind_energy.py:111 msgid "wind data points" msgstr "风数据点" -#: src/natcap/invest/wind_energy.py:90 -msgid "Map of the area(s) of interest over which to run the model and aggregate valuation results. Required if Run Valuation is selected and the Grid Connection Points table is provided." +#: src/natcap/invest/wind_energy.py:118 +msgid "" +"Map of the area(s) of interest over which to run the model and aggregate " +"valuation results. Required if Run Valuation is selected and the Grid " +"Connection Points table is provided." msgstr "运行模型和汇总估价结果的相关区域地图。如果选择了运行评估并提供了网格连接点表格,则需要。" -#: src/natcap/invest/wind_energy.py:107 -msgid "Map of the coastlines of landmasses in the area of interest. Required if the Minimum Distance and Maximum Distance inputs are provided." +#: src/natcap/invest/wind_energy.py:135 +msgid "" +"Map of the coastlines of landmasses in the area of interest. Required if " +"the Minimum Distance and Maximum Distance inputs are provided." msgstr "感兴趣的地区的陆地的海岸线地图。如果提供最小距离和最大距离的输入,则需要。" -#: src/natcap/invest/wind_energy.py:111 +#: src/natcap/invest/wind_energy.py:139 msgid "land polygon" msgstr "陆地多边形" -#: src/natcap/invest/wind_energy.py:119 +#: src/natcap/invest/wind_energy.py:147 msgid "Standard atmosphere air density." msgstr "标准大气的空气密度。" -#: src/natcap/invest/wind_energy.py:123 +#: src/natcap/invest/wind_energy.py:151 msgid "Exponent to use in the power curve function." msgstr "功率曲线函数中使用的指数。" -#: src/natcap/invest/wind_energy.py:126 -msgid "Cost to decommission a turbine as a proportion of the total upfront costs (cables, foundations, installation?)" +#: src/natcap/invest/wind_energy.py:154 +msgid "" +"Cost to decommission a turbine as a proportion of the total upfront costs" +" (cables, foundations, installation?)" msgstr "涡轮机退役的成本占前期总成本的比例(电缆、地基、安装?)" -#: src/natcap/invest/wind_energy.py:133 +#: src/natcap/invest/wind_energy.py:161 msgid "The operations and maintenance costs as a proportion of capex_arr" msgstr "运营和维护成本占资本支出的比例_arr" -#: src/natcap/invest/wind_energy.py:138 +#: src/natcap/invest/wind_energy.py:166 msgid "The miscellaneous costs as a proportion of capex_arr" msgstr "杂项费用占资本支出的比例_arr" -#: src/natcap/invest/wind_energy.py:143 +#: src/natcap/invest/wind_energy.py:171 msgid "The installation costs as a proportion of capex_arr" msgstr "安装费用占资本支出的比例_arr" -#: src/natcap/invest/wind_energy.py:149 +#: src/natcap/invest/wind_energy.py:177 msgid "The length of infield cable." msgstr "内场电缆的长度。" -#: src/natcap/invest/wind_energy.py:153 +#: src/natcap/invest/wind_energy.py:181 msgid "The cost of infield cable." msgstr "内场电缆的费用。" -#: src/natcap/invest/wind_energy.py:157 +#: src/natcap/invest/wind_energy.py:185 msgid "Cost of AC cable that scales with capacity." msgstr "随容量变化而变化的交流电缆的成本。" -#: src/natcap/invest/wind_energy.py:161 +#: src/natcap/invest/wind_energy.py:189 msgid "Cost of DC cable that scales with capacity." msgstr "随容量变化而变化的直流电缆的成本。" -#: src/natcap/invest/wind_energy.py:165 +#: src/natcap/invest/wind_energy.py:193 msgid "Cost of AC cable that scales with length." msgstr "随长度变化而变化的交流电缆的成本。" -#: src/natcap/invest/wind_energy.py:169 +#: src/natcap/invest/wind_energy.py:197 msgid "Cost of DC cable that scales with length." msgstr "与长度成比例的直流电缆的成本。" -#: src/natcap/invest/wind_energy.py:173 -msgid "The threshold above which a wind farm’s distance from the grid requires a switch from AC to DC power to overcome line losses which reduce the amount of energy delivered" +#: src/natcap/invest/wind_energy.py:201 +msgid "" +"The threshold above which a wind farm’s distance from the grid requires a" +" switch from AC to DC power to overcome line losses which reduce the " +"amount of energy delivered" msgstr "风电场与电网的距离超过这个阈值时,需要从交流电转换为直流电,以克服线路损耗,从而减少输送的能量" -#: src/natcap/invest/wind_energy.py:181 +#: src/natcap/invest/wind_energy.py:209 msgid "The expected lifetime of the facility" msgstr "设施的预期寿命" -#: src/natcap/invest/wind_energy.py:185 -msgid "Factor that translates carbon-free wind power to a corresponding amount of avoided CO2 emissions" +#: src/natcap/invest/wind_energy.py:213 +msgid "" +"Factor that translates carbon-free wind power to a corresponding amount " +"of avoided CO2 emissions" msgstr "将无碳的风力发电转化为相应的避免的二氧化碳排放量的因素" -#: src/natcap/invest/wind_energy.py:191 +#: src/natcap/invest/wind_energy.py:219 msgid "The reduction in air density per meter above sea level" msgstr "海平面以上每米的空气密度减少量" -#: src/natcap/invest/wind_energy.py:196 -msgid "The fraction of energy lost due to downtime, power conversion inefficiency, and electrical grid losses" +#: src/natcap/invest/wind_energy.py:224 +msgid "" +"The fraction of energy lost due to downtime, power conversion " +"inefficiency, and electrical grid losses" msgstr "由于停机、电力转换效率低下和电网损失而损失的能源部分" -#: src/natcap/invest/wind_energy.py:200 +#: src/natcap/invest/wind_energy.py:228 msgid "A table of wind energy infrastructure parameters." msgstr "风能基础设施参数表。" -#: src/natcap/invest/wind_energy.py:202 +#: src/natcap/invest/wind_energy.py:230 msgid "global wind energy parameters" msgstr "全球风能参数" -#: src/natcap/invest/wind_energy.py:210 +#: src/natcap/invest/wind_energy.py:238 msgid "Height of the turbine hub above sea level." msgstr "涡轮机轮毂高于海平面的高度。" -#: src/natcap/invest/wind_energy.py:214 +#: src/natcap/invest/wind_energy.py:242 msgid "Wind speed at which the turbine begins producing power." msgstr "涡轮机开始生产电力时的风速。" -#: src/natcap/invest/wind_energy.py:220 +#: src/natcap/invest/wind_energy.py:248 msgid "Minimum wind speed at which the turbine reaches its rated power output." msgstr "涡轮机达到额定输出功率的最低风速。" -#: src/natcap/invest/wind_energy.py:226 -msgid "Wind speed above which the turbine stops generating power for safety reasons." +#: src/natcap/invest/wind_energy.py:254 +msgid "" +"Wind speed above which the turbine stops generating power for safety " +"reasons." msgstr "风速,超过这个风速,涡轮机就会出于安全原因停止发电。" -#: src/natcap/invest/wind_energy.py:232 +#: src/natcap/invest/wind_energy.py:260 msgid "The turbine's rated power output." msgstr "涡轮机的额定输出功率。" -#: src/natcap/invest/wind_energy.py:236 +#: src/natcap/invest/wind_energy.py:264 msgid "The cost of one turbine." msgstr "一个涡轮机的成本。" -#: src/natcap/invest/wind_energy.py:238 +#: src/natcap/invest/wind_energy.py:266 msgid "A table of parameters specific to the type of turbine." msgstr "涡轮机类型特有的参数表。" -#: src/natcap/invest/wind_energy.py:239 +#: src/natcap/invest/wind_energy.py:267 msgid "turbine parameters" msgstr "涡轮机参数" -#: src/natcap/invest/wind_energy.py:245 +#: src/natcap/invest/wind_energy.py:273 msgid "The number of wind turbines per wind farm." msgstr "每个风电场的风力涡轮机数量。" -#: src/natcap/invest/wind_energy.py:246 +#: src/natcap/invest/wind_energy.py:274 msgid "number of turbines" msgstr "涡轮机的数量" -#: src/natcap/invest/wind_energy.py:251 +#: src/natcap/invest/wind_energy.py:279 msgid "Minimum depth for offshore wind farm installation." msgstr "海上风电场安装的最小深度。" -#: src/natcap/invest/wind_energy.py:252 +#: src/natcap/invest/wind_energy.py:280 msgid "minimum depth" msgstr "最小深度" -#: src/natcap/invest/wind_energy.py:257 +#: src/natcap/invest/wind_energy.py:285 msgid "Maximum depth for offshore wind farm installation." msgstr "海上风电场安装的最大深度。" -#: src/natcap/invest/wind_energy.py:258 +#: src/natcap/invest/wind_energy.py:286 msgid "maximum depth" msgstr "最大深度" -#: src/natcap/invest/wind_energy.py:264 -msgid "Minimum distance from shore for offshore wind farm installation. Required if Run Valuation is selected." +#: src/natcap/invest/wind_energy.py:292 +msgid "" +"Minimum distance from shore for offshore wind farm installation. Required" +" if Run Valuation is selected." msgstr "海上风电场安装的最小离岸距离。如果选择运行评估,则需要。" -#: src/natcap/invest/wind_energy.py:267 +#: src/natcap/invest/wind_energy.py:295 msgid "minimum distance" msgstr "最小距离" -#: src/natcap/invest/wind_energy.py:273 -msgid "Maximum distance from shore for offshore wind farm installation. Required if Run Valuation is selected." +#: src/natcap/invest/wind_energy.py:301 +msgid "" +"Maximum distance from shore for offshore wind farm installation. Required" +" if Run Valuation is selected." msgstr "海上风电场安装的最大离岸距离。如果选择运行评估,则需要。" -#: src/natcap/invest/wind_energy.py:276 +#: src/natcap/invest/wind_energy.py:304 msgid "maximum distance" msgstr "最大距离" -#: src/natcap/invest/wind_energy.py:281 +#: src/natcap/invest/wind_energy.py:309 msgid "Run the valuation component of the model." msgstr "运行估值模型。" -#: src/natcap/invest/wind_energy.py:288 +#: src/natcap/invest/wind_energy.py:316 msgid "The cost of the foundation for one turbine." msgstr "一个涡轮机的基础费用。" -#: src/natcap/invest/wind_energy.py:289 +#: src/natcap/invest/wind_energy.py:317 msgid "foundation cost" msgstr "基础费用" -#: src/natcap/invest/wind_energy.py:294 +#: src/natcap/invest/wind_energy.py:322 msgid "Annual discount rate to apply to valuation." msgstr "适用于估价的年度贴现率。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:402 -#: src/natcap/invest/wind_energy.py:295 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:408 +#: src/natcap/invest/wind_energy.py:323 msgid "discount rate" msgstr "折现率" -#: src/natcap/invest/wind_energy.py:325 -msgid "Table of grid and land connection points to which cables will connect. Required if Run Valuation is selected and Average Shore-to-Grid Distance is not provided." +#: src/natcap/invest/wind_energy.py:354 +msgid "" +"Table of grid and land connection points to which cables will connect. " +"Required if Run Valuation is selected and Average Shore-to-Grid Distance " +"is not provided." msgstr "电缆将连接的电网和陆地连接点的表格。如果选择了运行评估,并且没有提供海岸到网格的平均距离,则需要。" -#: src/natcap/invest/wind_energy.py:329 +#: src/natcap/invest/wind_energy.py:358 msgid "grid connection points" msgstr "电网连接点表" -#: src/natcap/invest/wind_energy.py:336 -msgid "Average distance to the onshore grid from coastal cable landing points. Required if Run Valuation is selected and the Grid Connection Points table is not provided." +#: src/natcap/invest/wind_energy.py:365 +msgid "" +"Average distance to the onshore grid from coastal cable landing points. " +"Required if Run Valuation is selected and the Grid Connection Points " +"table is not provided." msgstr "从沿海电缆登陆点到陆上电网的平均距离。如果选择运行评估,且未提供电网连接点表,则需要。" -#: src/natcap/invest/wind_energy.py:340 +#: src/natcap/invest/wind_energy.py:369 msgid "average shore-to-grid distance" msgstr "岸边到电网的平均距离" -#: src/natcap/invest/wind_energy.py:345 -msgid "Use a Wind Energy Price Table instead of calculating annual prices from the initial Energy Price and Rate of Price Change inputs." +#: src/natcap/invest/wind_energy.py:374 +msgid "" +"Use a Wind Energy Price Table instead of calculating annual prices from " +"the initial Energy Price and Rate of Price Change inputs." msgstr "使用风能价格表,而不是从最初的能源价格和价格变化率输入来计算年度价格。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:357 -#: src/natcap/invest/wind_energy.py:349 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:362 +#: src/natcap/invest/wind_energy.py:378 msgid "use price table" msgstr "使用价格表" -#: src/natcap/invest/wind_energy.py:357 -msgid "Consecutive years for each year in the lifespan of the wind farm. These may be the actual years: 2010, 2011, 2012..., or the number of the years after the starting date: 1, 2, 3,..." +#: src/natcap/invest/wind_energy.py:387 +msgid "" +"Consecutive years for each year in the lifespan of the wind farm. These " +"may be the actual years: 2010, 2011, 2012..., or the number of the years " +"after the starting date: 1, 2, 3,..." msgstr "风电场寿命期中每一年的连续年份。这些可以是实际年份:2010年、2011年、2012年......,也可以是起始日期之后的年份:1、2、3......。" -#: src/natcap/invest/wind_energy.py:366 +#: src/natcap/invest/wind_energy.py:396 msgid "Price of energy for each year." msgstr "每一年的能源价格。" -#: src/natcap/invest/wind_energy.py:370 -msgid "Table of yearly prices for wind energy. There must be a row for each year in the lifespan given in the 'time_period' column in the Global Wind Energy Parameters table. Required if Run Valuation and Use Price Table are selected." +#: src/natcap/invest/wind_energy.py:400 +msgid "" +"Table of yearly prices for wind energy. There must be a row for each year" +" in the lifespan given in the 'time_period' column in the Global Wind " +"Energy Parameters table. Required if Run Valuation and Use Price Table " +"are selected." msgstr "风力发电的年度价格表。在全球风能参数表的'时间_周期'栏中给出的寿命期内,每年必须有一行。如果选择了运行估值和使用价格表,则需要。" -#: src/natcap/invest/wind_energy.py:375 +#: src/natcap/invest/wind_energy.py:405 msgid "wind energy price table" msgstr "风能价格表" -#: src/natcap/invest/wind_energy.py:381 -msgid "The initial price of wind energy, at the first year in the wind energy farm lifespan. Required if Run Valuation is selected and Use Price Table is not selected." +#: src/natcap/invest/wind_energy.py:411 +msgid "" +"The initial price of wind energy, at the first year in the wind energy " +"farm lifespan. Required if Run Valuation is selected and Use Price Table " +"is not selected." msgstr "风力发电场寿命中第一年的风能初始价格。如果选择了运行评估和不选择使用价格表,则需要。" -#: src/natcap/invest/wind_energy.py:385 +#: src/natcap/invest/wind_energy.py:415 msgid "price of energy" msgstr "能源价格" -#: src/natcap/invest/wind_energy.py:390 -msgid "The annual rate of change in the price of wind energy. Required if Run Valuation is selected and Use Price Table is not selected." +#: src/natcap/invest/wind_energy.py:420 +msgid "" +"The annual rate of change in the price of wind energy. Required if Run " +"Valuation is selected and Use Price Table is not selected." msgstr "风能价格的年变化率。如果选择了运行估价和不选择使用价格表,则需要。" -#: src/natcap/invest/wind_energy.py:394 +#: src/natcap/invest/wind_energy.py:424 msgid "rate of price change" msgstr "价格变化率" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:115 -msgid "Analysis year {analysis_year} must be >= the latest snapshot year ({latest_year})" +#: src/natcap/invest/wind_energy.py:432 +msgid "Map of offset carbon emissions for a farm centered on each pixel" +msgstr "" + +#: src/natcap/invest/wind_energy.py:441 +msgid "Map of power density." +msgstr "" + +#: src/natcap/invest/wind_energy.py:448 +msgid "Map of energy harvested from a farm centered on each pixel." +msgstr "" + +#: src/natcap/invest/wind_energy.py:456 +msgid "" +"Map of the energy price that would be required to set the present value " +"of a farm centered on each pixel equal to zero." +msgstr "" + +#: src/natcap/invest/wind_energy.py:466 +msgid "Map of the net present value of a farm centered on each pixel." +msgstr "" + +#: src/natcap/invest/wind_energy.py:471 +msgid "Map of summarized data at each point." +msgstr "" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:116 +msgid "" +"Analysis year {analysis_year} must be >= the latest snapshot year " +"({latest_year})" msgstr "分析年份{analysis_year}必须>=最新快照年份({latest_year})" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:118 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:119 msgid "Raster for snapshot {snapshot_year} could not be validated." msgstr "快照{snapshot_year}的栅格不能被验证。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:174 -msgid "The snapshot year that this row's LULC raster represents. Each year in this table must be unique." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:121 +msgid "" +"The transition table expects values of {model_transitions} but found " +"values of {transition_values}." +msgstr "" + +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:177 +msgid "" +"The snapshot year that this row's LULC raster represents. Each year in " +"this table must be unique." msgstr "这一行的LULC栅格所代表的快照年份。此表中的每一年必须是唯一的。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:181 -msgid "Map of LULC in the given snapshot year. All values in this raster must have corresponding entries in the Biophysical Table and Landcover Transitions Table." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:184 +msgid "" +"Map of LULC in the given snapshot year. All values in this raster must " +"have corresponding entries in the Biophysical Table and Landcover " +"Transitions Table." msgstr "在给定的快照年份,LULC的地图。该栅格中的所有数值必须在生物物理表和土地覆被转换表中有相应的条目。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:188 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:191 msgid "A table mapping snapshot years to corresponding LULC maps." msgstr "一个将快照年份与相应的LULC地图相联系的表格。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:190 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:193 msgid "landcover snapshots table" msgstr "土地覆盖快照表" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:196 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:199 msgid "analysis year" msgstr "分析年" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:197 -msgid "A year that may be used to extend the analysis beyond the last snapshot year. If used, the model assumes that carbon will continue to accumulate or emit after the last snapshot year until the analysis year. This value must be greater than the final snapshot year." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:200 +msgid "" +"A year that may be used to extend the analysis beyond the last snapshot " +"year. If used, the model assumes that carbon will continue to accumulate " +"or emit after the last snapshot year until the analysis year. This value " +"must be greater than the final snapshot year." msgstr "一个可用于将分析延伸到最后一个快照年之后的年份。如果使用,模型假定碳在最后一个快照年之后将继续积累或排放,直到分析年。该值必须大于最后快照年。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:210 -msgid "The LULC code that represents this LULC class in the LULC snapshot rasters." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:214 +msgid "" +"The LULC code that represents this LULC class in the LULC snapshot " +"rasters." msgstr "在LULC快照栅格中代表该LULC类别的LULC代码。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:215 -msgid "Name of the LULC class. This label must be unique among the all the LULC classes." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:219 +msgid "" +"Name of the LULC class. This label must be unique among the all the LULC " +"classes." msgstr "LULC类别的名称。这个标签在所有LULC等级中必须是唯一的。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:221 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:225 msgid "The initial carbon stocks in the biomass pool for this LULC class." msgstr "该LULC等级的生物质库的初始碳储量。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:227 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:231 msgid "The initial carbon stocks in the soil pool for this LULC class." msgstr "该LULC等级的土壤池中的初始碳储量。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:233 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:237 msgid "The initial carbon stocks in the litter pool for this LULC class." msgstr "该LULC等级的垃圾池中的初始碳储量。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:240 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:244 msgid "The half-life of carbon in the biomass pool." msgstr "碳在生物质库中的半衰期。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:243 -msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a low-impact disturbance." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:247 +msgid "" +"Proportion of carbon stock in the biomass pool that is disturbed when a " +"cell transitions away from this LULC class in a low-impact disturbance." msgstr "当一个单元在低影响的干扰下从该LULC等级过渡到其他等级时,生物量池中碳储量的比例受到干扰。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:249 -msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a medium-impact disturbance." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:253 +msgid "" +"Proportion of carbon stock in the biomass pool that is disturbed when a " +"cell transitions away from this LULC class in a medium-impact " +"disturbance." msgstr "在中等影响的干扰下,当一个单元从该LULC等级过渡到其他等级时,生物量池中碳储量的比例受到干扰。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:255 -msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a high-impact disturbance." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:259 +msgid "" +"Proportion of carbon stock in the biomass pool that is disturbed when a " +"cell transitions away from this LULC class in a high-impact disturbance." msgstr "当一个单元在高影响扰动下从该LULC等级过渡到其他等级时,生物量池中碳储量的比例受到干扰。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:262 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:266 msgid "Annual rate of CO2E accumulation in the biomass pool." msgstr "生物量库中CO2E的年积累率。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:268 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:272 msgid "The half-life of carbon in the soil pool." msgstr "土壤池中的碳的半衰期。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:271 -msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a low-impact disturbance." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:275 +msgid "" +"Proportion of carbon stock in the soil pool that is disturbed when a cell" +" transitions away from this LULC class in a low-impact disturbance." msgstr "当一个单元在低影响的干扰中脱离该LULC等级时,土壤池中碳储量的比例受到干扰。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:277 -msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a medium-impact disturbance." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:281 +msgid "" +"Proportion of carbon stock in the soil pool that is disturbed when a cell" +" transitions away from this LULC class in a medium-impact disturbance." msgstr "在中等影响的干扰下,当一个单元从该LULC等级过渡到其他等级时,土壤池中的碳储量比例受到干扰。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:283 -msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a high-impact disturbance." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:287 +msgid "" +"Proportion of carbon stock in the soil pool that is disturbed when a cell" +" transitions away from this LULC class in a high-impact disturbance." msgstr "当一个单元在高影响的干扰中从该LULC等级过渡到其他等级时,土壤池中的碳储量比例受到干扰。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:290 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:294 msgid "Annual rate of CO2E accumulation in the soil pool." msgstr "土壤池中CO2E的年积累率。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:295 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:299 msgid "Annual rate of CO2E accumulation in the litter pool." msgstr "废弃物池中CO2E的年积累率。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:298 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:302 msgid "Table of biophysical properties for each LULC class." msgstr "每个LULC类别的生物物理特性表。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:301 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:305 msgid "landcover transitions table" msgstr "土地覆盖转换表" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:306 -msgid "LULC codes matching the codes in the biophysical table." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:311 +#, fuzzy +msgid "LULC class names matching those in the biophysical table." msgstr "LULC代码与生物物理表中的代码相匹配。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:313 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:318 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:97 msgid "a state of carbon accumulation" msgstr "积碳状态" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:316 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:321 msgid "high carbon disturbance rate" msgstr "高碳扰动率" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:319 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:324 msgid "medium carbon disturbance rate" msgstr "中等碳扰动率" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:322 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:327 msgid "low carbon disturbance rate" msgstr "低碳扰动率" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:325 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:330 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:106 msgid "no change in carbon" msgstr "碳无变化" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:328 -msgid "A transition matrix describing the type of carbon action that occurs when each LULC type transitions to each other type. Values in the first column, 'lulc-class', represents the original LULC class that is transitioned away from. Values in the first row represents the LULC class that is transitioned to. Each cell in the matrix is filled with an option indicating the effect on carbon when transitioning from that cell's row's LULC class to that cell's column's LULC class. The classes in this table must exactly match the classes in the Biophysical Table 'lulc-class' column. A cell may be left empty if the transition never occurs." -msgstr "一个过渡矩阵,描述每个LULC类型过渡到其他类型时发生的碳行动的类型。第一列中的数值,\"LULC-class\",代表被过渡到的原始LULC类别。第一行中的数值代表被过渡到的LULC类别。矩阵中的每个单元格都填有一个选项,表示从该单元格的行的LULC等级过渡到该单元格的列的LULC等级时对碳的影响。该表中的等级必须与生物物理表 \"LULC-Class \"列中的等级完全一致。如果转换从未发生,则单元格可以留空。" +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:333 +msgid "" +"A transition matrix describing the type of carbon action that occurs when" +" each LULC type transitions to each other type. Values in the first " +"column, 'lulc-class', represents the original LULC class that is " +"transitioned away from. Values in the first row represents the LULC class" +" that is transitioned to. Each cell in the matrix is filled with an " +"option indicating the effect on carbon when transitioning from that " +"cell's row's LULC class to that cell's column's LULC class. The classes " +"in this table must exactly match the classes in the Biophysical Table " +"'lulc-class' column. A cell may be left empty if the transition never " +"occurs." +msgstr "" +"一个过渡矩阵,描述每个LULC类型过渡到其他类型时发生的碳行动的类型。第一列中的数值,\"LULC-" +"class\",代表被过渡到的原始LULC类别。第一行中的数值代表被过渡到的LULC类别。矩阵中的每个单元格都填有一个选项,表示从该单元格的行的LULC等级过渡到该单元格的列的LULC等级时对碳的影响。该表中的等级必须与生物物理表" +" \"LULC-Class \"列中的等级完全一致。如果转换从未发生,则单元格可以留空。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:343 -msgid "A transition matrix mapping the type of carbon action undergone when one LULC type transitions to another." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:348 +msgid "" +"A transition matrix mapping the type of carbon action undergone when one " +"LULC type transitions to another." msgstr "当一种LULC类型过渡到另一种LULC类型时,一个过渡矩阵映射出所经历的碳行动的类型。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:351 -msgid "Enable net present valuation analysis based on carbon prices from either a yearly price table, or an initial price and yearly interest rate." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:356 +msgid "" +"Enable net present valuation analysis based on carbon prices from either " +"a yearly price table, or an initial price and yearly interest rate." msgstr "启用基于年度价格表的碳价格,或初始价格和年度利率的净现值分析。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:360 -msgid "Use a yearly price table, rather than an initial price and interest rate, to indicate carbon value over time." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:365 +msgid "" +"Use a yearly price table, rather than an initial price and interest rate," +" to indicate carbon value over time." msgstr "使用年度价格表,而不是初始价格和利率,以表明随着时间推移的碳价值。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:365 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:370 msgid "price" msgstr "价格" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:369 -msgid "The price of CO2E at the baseline year. Required if Do Valuation is selected and Use Price Table is not selected." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:374 +msgid "" +"The price of CO2E at the baseline year. Required if Do Valuation is " +"selected and Use Price Table is not selected." msgstr "基线年的CO2E价格。如果选择 \"做估值 \"且不选择 \"使用价格表\",则需要。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:374 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:379 msgid "interest rate" msgstr "利率" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:377 -msgid "Annual increase in the price of CO2E. Required if Do Valuation is selected and Use Price Table is not selected." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:382 +msgid "" +"Annual increase in the price of CO2E. Required if Do Valuation is " +"selected and Use Price Table is not selected." msgstr "CO2E价格的年度增长。如果选择 \"做估值 \"且不选择 \"使用价格表\",则需要。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:382 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:387 msgid "price table" msgstr "价格表" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:389 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:395 msgid "Each year from the snapshot year to analysis year." msgstr "从快照年到分析年的每一年。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:394 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:400 msgid "Price of CO2E in that year." msgstr "当年的CO2E价格。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:396 -msgid "Table of annual CO2E prices for each year from the baseline year to the final snapshot or analysis year. Required if Do Valuation is selected and Use Price Table is selected." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:402 +msgid "" +"Table of annual CO2E prices for each year from the baseline year to the " +"final snapshot or analysis year. Required if Do Valuation is selected and" +" Use Price Table is selected." msgstr "从基线年到最终快照或分析年每年的CO2E价格表。如果选择 \"做估值 \"并选择 \"使用价格表\",则需要。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:405 -msgid "Annual discount rate on the price of carbon. This is compounded each year after the baseline year. Required if Run Valuation is selected." +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:411 +msgid "" +"Annual discount rate on the price of carbon. This is compounded each year" +" after the baseline year. Required if Run Valuation is selected." msgstr "碳价格的年度折扣率。在基线年之后每年复利。如果选择运行评估,则需要。" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:30 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:33 msgid "LULC lookup table" msgstr "LULC查询表" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:32 -msgid "A table mapping LULC codes from the snapshot rasters to the corresponding LULC class names, and whether or not the class is a coastal blue carbon habitat." +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:35 +msgid "" +"A table mapping LULC codes from the snapshot rasters to the corresponding" +" LULC class names, and whether or not the class is a coastal blue carbon " +"habitat." msgstr "将快照栅格中的LULC代码映射到相应的LULC等级名称,以及该等级是否为沿海蓝碳生境的表格。" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:39 -msgid "LULC code. Every value in the snapshot LULC maps must have a corresponding entry in this column." +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:43 +msgid "" +"LULC code. Every value in the snapshot LULC maps must have a " +"corresponding entry in this column." msgstr "LULC代码。在快照LULC地图中的每一个值都必须在这一栏中有一个相应的条目。" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:45 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:49 msgid "Name of the LULC class." msgstr "LULC等级的名称。" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:48 -msgid "Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if not." +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:52 +msgid "" +"Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if " +"not." msgstr "如果该LULC类别是沿海蓝碳生境,则输入TRUE,如果不是,则输入FALSE。" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:59 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:63 msgid "Year to snapshot." msgstr "年到快照。" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:63 -msgid "Map of LULC in the snapshot year. All values in this raster must have corresponding entries in the LULC Lookup table." +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:67 +msgid "" +"Map of LULC in the snapshot year. All values in this raster must have " +"corresponding entries in the LULC Lookup table." msgstr "快照年份的LULC地图。该栅格中的所有数值必须在LULC查询表中有相应的条目。" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:69 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:73 msgid "A table mapping snapshot years to corresponding LULC maps for each year." msgstr "一个表格,将快照年份与每年相应的LULC地图进行映射。" -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:72 +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:76 msgid "LULC snapshots table" msgstr "土地覆盖快照表" +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:90 +msgid "LULC codes matching the codes in the biophysical table." +msgstr "LULC代码与生物物理表中的代码相匹配。" + +#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:100 +msgid "" +"Carbon disturbance occurred. Replace this with one of ‘low-impact-" +"disturb’, ‘med-impact-disturb’, or ‘high-impact-disturb’ to indicate the " +"degree of disturbance." +msgstr "" + #: src/natcap/invest/delineateit/delineateit.py:46 -msgid "Detect pour points (watershed outlets) based on the DEM, and use these instead of a user-provided outlet features vector." +msgid "" +"Detect pour points (watershed outlets) based on the DEM, and use these " +"instead of a user-provided outlet features vector." msgstr "根据DEM检测倾倒点(流域出口),并使用这些倾倒点而不是用户提供的出口特征矢量。" #: src/natcap/invest/delineateit/delineateit.py:50 @@ -2573,7 +3715,9 @@ msgid "detect pour points" msgstr "检测倾倒点" #: src/natcap/invest/delineateit/delineateit.py:57 -msgid "A map of watershed outlets from which to delineate the watersheds. Required if Detect Pour Points is not checked." +msgid "" +"A map of watershed outlets from which to delineate the watersheds. " +"Required if Detect Pour Points is not checked." msgstr "流域出口的地图,据此划定流域。如果没有勾选检测倾倒点,则需要。" #: src/natcap/invest/delineateit/delineateit.py:60 @@ -2581,8 +3725,16 @@ msgid "watershed outlets" msgstr "流域出口" #: src/natcap/invest/delineateit/delineateit.py:65 -msgid "Whether to snap point geometries to the nearest stream pixel. If ``True``, ``args['flow_threshold']`` and ``args['snap_distance']`` must also be defined. If a point is equally near to more than one stream pixel, it will be snapped to the stream pixel with the highest flow accumulation value. This has no effect if Detect Pour Points is selected." -msgstr "是否将点的几何图形抓取到最近的河流栅格。 如果是 \"True\",还必须定义 \"args['flow_threshold']\"和 \"args['snap_distance''\"。如果一个点同样靠近一个以上的河流栅格,它将被捕捉到具有最高流量累积值的河流栅格。如果选择了Detect Pour Points,这就没有影响。" +msgid "" +"Whether to snap point geometries to the nearest stream pixel. If " +"``True``, ``args['flow_threshold']`` and ``args['snap_distance']`` must " +"also be defined. If a point is equally near to more than one stream " +"pixel, it will be snapped to the stream pixel with the highest flow " +"accumulation value. This has no effect if Detect Pour Points is selected." +msgstr "" +"是否将点的几何图形抓取到最近的河流栅格。 如果是 \"True\",还必须定义 \"args['flow_threshold']\"和 " +"\"args['snap_distance''\"。如果一个点同样靠近一个以上的河流栅格,它将被捕捉到具有最高流量累积值的河流栅格。如果选择了Detect" +" Pour Points,这就没有影响。" #: src/natcap/invest/delineateit/delineateit.py:73 msgid "snap points to the nearest stream" @@ -2593,7 +3745,9 @@ msgid "about Required if Snap Points is selected." msgstr "如果选择了Snap Points,则需要。" #: src/natcap/invest/delineateit/delineateit.py:87 -msgid "Maximum distance to relocate watershed outlet points in order to snap them to a stream. Required if Snap Points is selected." +msgid "" +"Maximum distance to relocate watershed outlet points in order to snap " +"them to a stream. Required if Snap Points is selected." msgstr "重新定位流域出口点的最大距离,以便将其锁定在一个流上。如果选择卡住点,则需要。" #: src/natcap/invest/delineateit/delineateit.py:91 @@ -2601,91 +3755,128 @@ msgid "snap distance" msgstr "捕捉距离" #: src/natcap/invest/delineateit/delineateit.py:96 -msgid "Skip delineation for any invalid geometries found in the Outlet Features. Otherwise, an invalid geometry will cause the model to crash." +msgid "" +"Skip delineation for any invalid geometries found in the Outlet Features." +" Otherwise, an invalid geometry will cause the model to crash." msgstr "跳过在出口特征中发现的任何无效几何图形的划线。否则,一个无效的几何图形将导致模型崩溃。" #: src/natcap/invest/delineateit/delineateit.py:100 msgid "skip invalid geometries" msgstr "跳过无效的几何图形" -#: src/natcap/invest/ndr/ndr.py:25 +#: src/natcap/invest/ndr/ndr.py:26 msgid "Either calc_n or calc_p must be True" msgstr "计算_n或计算_p必须为真" -#: src/natcap/invest/ndr/ndr.py:47 -msgid "All values in this raster must have corresponding entries in the Biophysical table." +#: src/natcap/invest/ndr/ndr.py:48 +msgid "" +"All values in this raster must have corresponding entries in the " +"Biophysical table." msgstr "该光栅中的所有数值必须在生物物理表中有相应的条目。" -#: src/natcap/invest/ndr/ndr.py:57 -msgid "Map of runoff potential, the capacity to transport nutrients downslope. This can be a quickflow index or annual precipitation. Any units are allowed since the values will be normalized by their average." +#: src/natcap/invest/ndr/ndr.py:58 +msgid "" +"Map of runoff potential, the capacity to transport nutrients downslope. " +"This can be a quickflow index or annual precipitation. Any units are " +"allowed since the values will be normalized by their average." msgstr "径流潜力图,即向下坡输送营养物质的能力。这可以是一个快速流指数或年降水量。任何单位都是允许的,因为这些值将以其平均值为标准。" -#: src/natcap/invest/ndr/ndr.py:62 +#: src/natcap/invest/ndr/ndr.py:63 msgid "nutrient runoff proxy" msgstr "营养物质径流代理" -#: src/natcap/invest/ndr/ndr.py:69 -msgid "Map of the boundaries of the watershed(s) over which to aggregate the model results." +#: src/natcap/invest/ndr/ndr.py:70 +msgid "" +"Map of the boundaries of the watershed(s) over which to aggregate the " +"model results." msgstr "汇总模型结果的流域边界图。" -#: src/natcap/invest/ndr/ndr.py:81 +#: src/natcap/invest/ndr/ndr.py:83 msgid "The nutrient loading for this land use class." msgstr "该土地使用类别的营养负荷。" -#: src/natcap/invest/ndr/ndr.py:85 -msgid "Maximum nutrient retention efficiency. This is the maximum proportion of the nutrient that is retained on this LULC class." +#: src/natcap/invest/ndr/ndr.py:87 +msgid "" +"Maximum nutrient retention efficiency. This is the maximum proportion of " +"the nutrient that is retained on this LULC class." msgstr "最大养分保留效率。这是保留在该LULC等级上的最大养分比例。" -#: src/natcap/invest/ndr/ndr.py:92 -msgid "The distance after which it is assumed that this LULC type retains the nutrient at its maximum capacity. If nutrients travel a shorter distance that this, the retention efficiency will be less than the maximum value eff_x, following an exponential decay." +#: src/natcap/invest/ndr/ndr.py:94 +msgid "" +"The distance after which it is assumed that this LULC type retains the " +"nutrient at its maximum capacity. If nutrients travel a shorter distance " +"that this, the retention efficiency will be less than the maximum value " +"eff_x, following an exponential decay." msgstr "假设该LULC类型以其最大能力保留营养物的距离。如果营养物质的移动距离比这短,保留效率将小于最大值eff_x,呈指数衰减。" -#: src/natcap/invest/ndr/ndr.py:102 -msgid "The proportion of the total amount of nitrogen that are dissolved into the subsurface. By default, this value should be set to 0, indicating that all nutrients are delivered via surface flow. There is no equivalent of this for phosphorus." +#: src/natcap/invest/ndr/ndr.py:104 +msgid "" +"The proportion of the total amount of nitrogen that are dissolved into " +"the subsurface. By default, this value should be set to 0, indicating " +"that all nutrients are delivered via surface flow. There is no equivalent" +" of this for phosphorus." msgstr "溶解到地表下的氮总量的比例。默认情况下,这个值应该设置为0,表示所有的营养物质都通过地表流输送。对于磷,没有相应的数值。" -#: src/natcap/invest/ndr/ndr.py:109 -msgid "A table mapping each LULC class to its biophysical properties related to nutrient load and retention. Replace '[NUTRIENT]' in the column names with 'n' or 'p' for nitrogen or phosphorus respectively. Nitrogen data must be provided if Calculate Nitrogen is selected. Phosphorus data must be provided if Calculate Phosphorus is selected. All LULC codes in the LULC raster must have corresponding entries in this table." -msgstr "将每个LULC等级与其与养分负荷和保留有关的生物物理特性相匹配的表格。将列名中的\"[NUTRIENT]\"分别用 \"n \"或 \"p \"代替氮或磷。如果选择计算氮,必须提供氮的数据。如果选择计算磷,则必须提供磷的数据。LULC栅格中的所有LULC代码必须在此表中有相应的条目。" +#: src/natcap/invest/ndr/ndr.py:111 +msgid "" +"A table mapping each LULC class to its biophysical properties related to " +"nutrient load and retention. Replace '[NUTRIENT]' in the column names " +"with 'n' or 'p' for nitrogen or phosphorus respectively. Nitrogen data " +"must be provided if Calculate Nitrogen is selected. Phosphorus data must " +"be provided if Calculate Phosphorus is selected. All LULC codes in the " +"LULC raster must have corresponding entries in this table." +msgstr "" +"将每个LULC等级与其与养分负荷和保留有关的生物物理特性相匹配的表格。将列名中的\"[NUTRIENT]\"分别用 \"n \"或 \"p " +"\"代替氮或磷。如果选择计算氮,必须提供氮的数据。如果选择计算磷,则必须提供磷的数据。LULC栅格中的所有LULC代码必须在此表中有相应的条目。" -#: src/natcap/invest/ndr/ndr.py:122 +#: src/natcap/invest/ndr/ndr.py:124 msgid "Calculate phosphorus retention and export." msgstr "计算磷的保留和输出。" -#: src/natcap/invest/ndr/ndr.py:123 +#: src/natcap/invest/ndr/ndr.py:125 msgid "calculate phosphorus" msgstr "计算磷" -#: src/natcap/invest/ndr/ndr.py:127 +#: src/natcap/invest/ndr/ndr.py:129 msgid "Calculate nitrogen retention and export." msgstr "计算氮的保留和输出。" -#: src/natcap/invest/ndr/ndr.py:128 +#: src/natcap/invest/ndr/ndr.py:130 msgid "calculate nitrogen" msgstr "计算氮" -#: src/natcap/invest/ndr/ndr.py:136 -msgid "Calibration parameter that determines the shape of the relationship between hydrologic connectivity (the degree of connection from patches of land to the stream) and the nutrient delivery ratio (percentage of nutrient that actually reaches the stream)." +#: src/natcap/invest/ndr/ndr.py:138 +msgid "" +"Calibration parameter that determines the shape of the relationship " +"between hydrologic connectivity (the degree of connection from patches of" +" land to the stream) and the nutrient delivery ratio (percentage of " +"nutrient that actually reaches the stream)." msgstr "校准参数,决定了水文连通性(土地斑块与河流的连接程度)和营养物质输送率(实际到达河流的营养物质百分比)之间关系的形状。" -#: src/natcap/invest/ndr/ndr.py:142 src/natcap/invest/sdr/sdr.py:110 +#: src/natcap/invest/ndr/ndr.py:144 src/natcap/invest/sdr/sdr.py:112 msgid "Borselli k parameter" msgstr "Borselli k参数" -#: src/natcap/invest/ndr/ndr.py:148 +#: src/natcap/invest/ndr/ndr.py:150 msgid "subsurface critical length (nitrogen)" msgstr "地下临界长度(氮气)" -#: src/natcap/invest/ndr/ndr.py:149 -msgid "The distance traveled (subsurface and downslope) after which it is assumed that soil retains nitrogen at its maximum capacity. Required if Calculate Nitrogen is selected." +#: src/natcap/invest/ndr/ndr.py:151 +msgid "" +"The distance traveled (subsurface and downslope) after which it is " +"assumed that soil retains nitrogen at its maximum capacity. Required if " +"Calculate Nitrogen is selected." msgstr "假设土壤以最大容量保留氮的距离(地表下和下坡)。如果选择 \"计算氮\",则需要。" -#: src/natcap/invest/ndr/ndr.py:157 +#: src/natcap/invest/ndr/ndr.py:159 msgid "subsurface maximum retention efficiency (nitrogen)" msgstr "地下最大保留效率(氮)。" -#: src/natcap/invest/ndr/ndr.py:158 -msgid "The maximum nitrogen retention efficiency that can be reached through subsurface flow. This characterizes the retention due to biochemical degradation in soils. Required if Calculate Nitrogen is selected." +#: src/natcap/invest/ndr/ndr.py:160 +msgid "" +"The maximum nitrogen retention efficiency that can be reached through " +"subsurface flow. This characterizes the retention due to biochemical " +"degradation in soils. Required if Calculate Nitrogen is selected." msgstr "通过地下流动可达到的最大氮保留效率。这表征了由于土壤中的生物化学降解而产生的滞留。如果选择计算氮,则需要。" #: src/natcap/invest/recreation/recmodel_client.py:51 @@ -2701,31 +3892,46 @@ msgid "The type of predictor file provided in the 'path' column." msgstr "路径栏中提供的预测器文件的类型。" #: src/natcap/invest/recreation/recmodel_client.py:66 -msgid "Predictor is a raster. Metric is the mean of values within the AOI grid cell or polygon." +msgid "" +"Predictor is a raster. Metric is the mean of values within the AOI grid " +"cell or polygon." msgstr "预测器是一个栅格。度量是AOI网格单元或多边形内数值的平均值。" #: src/natcap/invest/recreation/recmodel_client.py:70 -msgid "Predictor is a raster. Metric is the sum of values within the AOI grid cell or polygon." +msgid "" +"Predictor is a raster. Metric is the sum of values within the AOI grid " +"cell or polygon." msgstr "预测器是一个栅格。度量是AOI网格单元或多边形内的数值之和。" #: src/natcap/invest/recreation/recmodel_client.py:74 -msgid "Predictor is a point vector. Metric is the number of points within each AOI grid cell or polygon." +msgid "" +"Predictor is a point vector. Metric is the number of points within each " +"AOI grid cell or polygon." msgstr "预测器是一个点矢量。度量是每个AOI网格单元或多边形内的点的数量。" #: src/natcap/invest/recreation/recmodel_client.py:78 -msgid "Predictor is a point vector. Metric is the Euclidean distance between the center of each AOI grid cell and the nearest point in this layer." +#, fuzzy +msgid "" +"Predictor is a point vector. Metric is the Euclidean distance between the" +" centroid of each AOI grid cell and the nearest point in this layer." msgstr "预测器是一个点矢量。度量是每个AOI网格单元的中心与本层最近的点之间的欧几里得距离。" #: src/natcap/invest/recreation/recmodel_client.py:83 -msgid "Predictor is a line vector. Metric is the total length of the lines that fall within each AOI grid cell." +msgid "" +"Predictor is a line vector. Metric is the total length of the lines that " +"fall within each AOI grid cell." msgstr "预测器是一个线矢量。度量是属于每个AOI网格单元的线的总长度。" #: src/natcap/invest/recreation/recmodel_client.py:87 -msgid "Predictor is a polygon vector. Metric is the area of overlap between the polygon and each AOI grid cell." +msgid "" +"Predictor is a polygon vector. Metric is the area of overlap between the " +"polygon and each AOI grid cell." msgstr "预测器是一个多边形矢量。度量是多边形与每个AOI网格单元之间的重叠面积。" #: src/natcap/invest/recreation/recmodel_client.py:91 -msgid "Predictor is a polygon vector. Metric is the percentage (0-100) of overlapping area between the polygon and each AOI grid cell." +msgid "" +"Predictor is a polygon vector. Metric is the percentage (0-100) of " +"overlapping area between the polygon and each AOI grid cell." msgstr "预测器是一个多边形矢量。衡量标准是多边形与每个AOI网格单元之间的重叠面积百分比(0-100)。" #: src/natcap/invest/recreation/recmodel_client.py:110 @@ -2749,7 +3955,10 @@ msgid "port" msgstr "端口" #: src/natcap/invest/recreation/recmodel_client.py:134 -msgid "Year at which to start photo user-day calculations. Calculations start on the first day of the year. Year must be in the range 2005 - 2017, and must be less than or equal to the End Year." +msgid "" +"Year at which to start photo user-day calculations. Calculations start on" +" the first day of the year. Year must be in the range 2005 - 2017, and " +"must be less than or equal to the End Year." msgstr "开始计算照片用户日的年份。计算从该年的第一天开始。年份必须在2005-2017范围内,并且必须小于或等于结束年份。" #: src/natcap/invest/recreation/recmodel_client.py:139 @@ -2757,7 +3966,10 @@ msgid "start year" msgstr "起始年份" #: src/natcap/invest/recreation/recmodel_client.py:145 -msgid "Year at which to end photo user-day calculations. Calculations continue through the last day of the year. Year must be in the range 2005 - 2017, and must be greater than or equal to the Start Year." +msgid "" +"Year at which to end photo user-day calculations. Calculations continue " +"through the last day of the year. Year must be in the range 2005 - 2017, " +"and must be greater than or equal to the Start Year." msgstr "结束照片用户日计算的年份。计算会持续到该年的最后一天。年份必须在2005-2017范围内,并且必须大于或等于起始年份。" #: src/natcap/invest/recreation/recmodel_client.py:150 @@ -2765,7 +3977,9 @@ msgid "end year" msgstr "结束年份" #: src/natcap/invest/recreation/recmodel_client.py:155 -msgid "Divide the AOI polygons into equal-sized grid cells, and compute results for those cells instead of the original polygons." +msgid "" +"Divide the AOI polygons into equal-sized grid cells, and compute results " +"for those cells instead of the original polygons." msgstr "将AOI的多边形划分为同等大小的网格单元,并对这些单元而非原始多边形进行计算。" #: src/natcap/invest/recreation/recmodel_client.py:159 @@ -2781,7 +3995,9 @@ msgid "hexagon" msgstr "六边形" #: src/natcap/invest/recreation/recmodel_client.py:168 -msgid "The shape of grid cells to make within the AOI polygons. Required if Grid AOI is selected." +msgid "" +"The shape of grid cells to make within the AOI polygons. Required if Grid" +" AOI is selected." msgstr "在AOI多边形范围内制作的网格单元的形状。如果选择了网格AOI,则需要。" #: src/natcap/invest/recreation/recmodel_client.py:171 @@ -2789,223 +4005,591 @@ msgid "grid type" msgstr "网格类型" #: src/natcap/invest/recreation/recmodel_client.py:178 -msgid "Size of grid cells to make, measured in the projection units of the AOI. If the Grid Type is 'square', this is the length of each side of the square. If the Grid Type is 'hexagon', this is the hexagon's maximal diameter." -msgstr "要制作的网格单元的尺寸,以AOI的投影单位衡量。如果网格类型是 \"正方形\",这就是正方形的每条边的长度。如果网格类型是 \"六边形\",这是该六边形的最大直径。" +msgid "" +"Size of grid cells to make, measured in the projection units of the AOI. " +"If the Grid Type is 'square', this is the length of each side of the " +"square. If the Grid Type is 'hexagon', this is the hexagon's maximal " +"diameter." +msgstr "" +"要制作的网格单元的尺寸,以AOI的投影单位衡量。如果网格类型是 \"正方形\",这就是正方形的每条边的长度。如果网格类型是 " +"\"六边形\",这是该六边形的最大直径。" #: src/natcap/invest/recreation/recmodel_client.py:183 msgid "cell size" msgstr "单元大小" -#: src/natcap/invest/recreation/recmodel_client.py:188 -msgid "Run the regression model using the predictor table and scenario table, if provided." -msgstr "使用预测表和情景表(如果提供)运行回归模型。" +#: src/natcap/invest/recreation/recmodel_client.py:188 +msgid "" +"Run the regression model using the predictor table and scenario table, if" +" provided." +msgstr "使用预测表和情景表(如果提供)运行回归模型。" + +#: src/natcap/invest/recreation/recmodel_client.py:191 +msgid "compute regression" +msgstr "计算回归" + +#: src/natcap/invest/recreation/recmodel_client.py:198 +msgid "" +"A table that maps predictor IDs to spatial files and their predictor " +"metric types. The file paths can be absolute or relative to the table." +msgstr "一个将预测器ID映射到空间文件及其预测器度量类型的表格。文件路径可以是绝对的,也可以是相对于该表的。" + +#: src/natcap/invest/recreation/recmodel_client.py:202 +msgid "predictor table" +msgstr "预测表" + +#: src/natcap/invest/recreation/recmodel_client.py:209 +msgid "" +"A table of future or alternative scenario predictors. Maps IDs to files " +"and their types. The file paths can be absolute or relative to the table." +msgstr "一个未来或替代方案的预测表。将ID映射到文件和它们的类型。文件路径可以是绝对的,也可以是相对于该表的。" + +#: src/natcap/invest/recreation/recmodel_client.py:213 +msgid "scenario predictor table" +msgstr "情景预测表" + +#: src/natcap/invest/recreation/recmodel_client.py:218 +msgid "Copy of the the AOI vector with aggregate attributes added." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:223 +msgid "The average photo-user-days per year" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:229 +msgid "The average photo-user-days for each month." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:237 +msgid "Table of monthly photo-user-days." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:242 +#, fuzzy +msgid "Polygon ID" +msgstr "陆地多边形" + +#: src/natcap/invest/recreation/recmodel_client.py:245 +msgid "Total photo-user-days counted in each cell in the given month." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:255 +msgid "AOI polygons with their corresponding predictor attributes." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:262 +#: src/natcap/invest/recreation/recmodel_client.py:287 +msgid "Predictor attribute value for each polygon." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:269 +msgid "" +"This is a text file output of the regression analysis. It includes " +"estimates for each predictor variable. It also contains a “server id " +"hash” value which can be used to correlate the PUD result with the data " +"available on the PUD server. If these results are used in publication " +"this hash should be included with the results for reproducibility." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:279 +msgid "" +"AOI polygons with their corresponding predictor attributes in the " +"scenario." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:293 +msgid "The estimated PUD_YR_AVG per polygon." +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:301 +msgid "Copy of the input AOI, gridded if applicable." +msgstr "" -#: src/natcap/invest/recreation/recmodel_client.py:191 -msgid "compute regression" -msgstr "计算回归" +#: src/natcap/invest/recreation/recmodel_client.py:307 +msgid "Compressed AOI" +msgstr "" -#: src/natcap/invest/recreation/recmodel_client.py:197 -msgid "A table that maps predictor IDs to spatial files and their predictor metric types. The file paths can be absolute or relative to the table." -msgstr "一个将预测器ID映射到空间文件及其预测器度量类型的表格。文件路径可以是绝对的,也可以是相对于该表的。" +#: src/natcap/invest/recreation/recmodel_client.py:310 +msgid "aggregated predictor values within each polygon" +msgstr "" -#: src/natcap/invest/recreation/recmodel_client.py:201 -msgid "predictor table" +#: src/natcap/invest/recreation/recmodel_client.py:314 +#, fuzzy +msgid "Predictor estimates" msgstr "预测表" -#: src/natcap/invest/recreation/recmodel_client.py:207 -msgid "A table of future or alternative scenario predictors. Maps IDs to files and their types. The file paths can be absolute or relative to the table." -msgstr "一个未来或替代方案的预测表。将ID映射到文件和它们的类型。文件路径可以是绝对的,也可以是相对于该表的。" +#: src/natcap/invest/recreation/recmodel_client.py:317 +msgid "Compressed photo-user-day data" +msgstr "" -#: src/natcap/invest/recreation/recmodel_client.py:211 -msgid "scenario predictor table" -msgstr "情景预测表" +#: src/natcap/invest/recreation/recmodel_client.py:319 +msgid "Pickled dictionary mapping FIDs to shapely geometries" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:326 +msgid "aggregated scenario predictor values within each polygon" +msgstr "" + +#: src/natcap/invest/recreation/recmodel_client.py:333 +msgid "Server version info" +msgstr "" -#: src/natcap/invest/scenic_quality/scenic_quality.py:67 +#: src/natcap/invest/scenic_quality/scenic_quality.py:66 msgid "features impacting scenic quality" msgstr "影响风景质量的特征" -#: src/natcap/invest/scenic_quality/scenic_quality.py:75 -msgid "Maximum length of the line of sight originating from a viewpoint. The value can either be positive (preferred) or negative (kept for backwards compatibility), but is converted to a positive number. If this field is not provided, the model will include all pixels in the DEM in the visibility analysis. RADIUS preferred, but may also be called RADIUS2 for backwards compatibility." +#: src/natcap/invest/scenic_quality/scenic_quality.py:74 +msgid "" +"Maximum length of the line of sight originating from a viewpoint. The " +"value can either be positive (preferred) or negative (kept for backwards " +"compatibility), but is converted to a positive number. If this field is " +"not provided, the model will include all pixels in the DEM in the " +"visibility analysis. RADIUS preferred, but may also be called RADIUS2 for" +" backwards compatibility." msgstr "源自一个观点的视线的最大长度。该值可以是正数(首选)或负数(为向后兼容而保留),但要转换为正数。如果不提供这个字段,模型将在可见度分析中包括DEM中的所有像素。首选RADIUS,但也可以称为RADIUS2,以便向后兼容。" -#: src/natcap/invest/scenic_quality/scenic_quality.py:88 -msgid "Viewshed importance coefficient. If this field is provided, the values are used to weight each feature's viewshed impacts. If not provided, all viewsheds are equally weighted with a weight of 1." +#: src/natcap/invest/scenic_quality/scenic_quality.py:87 +msgid "" +"Viewshed importance coefficient. If this field is provided, the values " +"are used to weight each feature's viewshed impacts. If not provided, all " +"viewsheds are equally weighted with a weight of 1." msgstr "景观重要性系数。如果提供了这个字段,其值将用于加权每个特征的视域影响。如果没有提供,则所有视域的权重相同,权重为1。" -#: src/natcap/invest/scenic_quality/scenic_quality.py:97 -msgid "Viewpoint height, the elevation above the ground of each feature. If this field is not provided, defaults to 0." +#: src/natcap/invest/scenic_quality/scenic_quality.py:96 +msgid "" +"Viewpoint height, the elevation above the ground of each feature. If this" +" field is not provided, defaults to 0." msgstr "视点高度,每个特征在地面上的高度。如果没有提供这个字段,默认为0。" -#: src/natcap/invest/scenic_quality/scenic_quality.py:102 -msgid "Map of locations of objects that negatively affect scenic quality. This must have the same projection as the DEM." +#: src/natcap/invest/scenic_quality/scenic_quality.py:101 +msgid "" +"Map of locations of objects that negatively affect scenic quality. This " +"must have the same projection as the DEM." msgstr "对景区质量有负面影响的物体的位置图。这必须具有与DEM相同的投影。" -#: src/natcap/invest/scenic_quality/scenic_quality.py:112 +#: src/natcap/invest/scenic_quality/scenic_quality.py:111 msgid "refractivity coefficient" msgstr "折射系数" -#: src/natcap/invest/scenic_quality/scenic_quality.py:114 -msgid "The refractivity coefficient corrects for the curvature of the earth and refraction of visible light in air." +#: src/natcap/invest/scenic_quality/scenic_quality.py:113 +msgid "" +"The refractivity coefficient corrects for the curvature of the earth and " +"refraction of visible light in air." msgstr "折射率系数修正了地球的曲率和可见光在空气中的折射。" -#: src/natcap/invest/scenic_quality/scenic_quality.py:125 +#: src/natcap/invest/scenic_quality/scenic_quality.py:124 msgid "Valuation function" msgstr "估值功能" -#: src/natcap/invest/scenic_quality/scenic_quality.py:129 +#: src/natcap/invest/scenic_quality/scenic_quality.py:128 msgid "linear: a + bx" msgstr "线性:a + bx" -#: src/natcap/invest/scenic_quality/scenic_quality.py:130 +#: src/natcap/invest/scenic_quality/scenic_quality.py:129 msgid "logarithmic: a + b log(x+1)" msgstr "对数:a + b log(x+1)" -#: src/natcap/invest/scenic_quality/scenic_quality.py:132 +#: src/natcap/invest/scenic_quality/scenic_quality.py:131 msgid "exponential: a * e^(-bx)" msgstr "指数:a * e^(-bx)" -#: src/natcap/invest/scenic_quality/scenic_quality.py:134 -msgid "Valuation function used to calculate the visual impact of each feature, given distance from the feature 'x' and parameters 'a' and 'b'." +#: src/natcap/invest/scenic_quality/scenic_quality.py:133 +msgid "" +"Valuation function used to calculate the visual impact of each feature, " +"given distance from the feature 'x' and parameters 'a' and 'b'." msgstr "用于计算每个特征的视觉影响的评价函数,给定与特征'x'的距离和参数'a'和'b'。" -#: src/natcap/invest/scenic_quality/scenic_quality.py:140 +#: src/natcap/invest/scenic_quality/scenic_quality.py:139 msgid "coefficient a" msgstr "系数a" -#: src/natcap/invest/scenic_quality/scenic_quality.py:144 +#: src/natcap/invest/scenic_quality/scenic_quality.py:143 msgid "First coefficient ('a') used by the valuation function" msgstr "估值函数使用的第一个系数('a')" -#: src/natcap/invest/scenic_quality/scenic_quality.py:147 +#: src/natcap/invest/scenic_quality/scenic_quality.py:146 msgid "coefficient b" msgstr "系数b" -#: src/natcap/invest/scenic_quality/scenic_quality.py:151 +#: src/natcap/invest/scenic_quality/scenic_quality.py:150 msgid "Second coefficient ('b') used by the valuation function" msgstr "估值函数使用的第二个系数('b')" -#: src/natcap/invest/scenic_quality/scenic_quality.py:154 +#: src/natcap/invest/scenic_quality/scenic_quality.py:153 msgid "maximum valuation radius" msgstr "最大估价半径" -#: src/natcap/invest/scenic_quality/scenic_quality.py:159 -msgid "Valuation will only be computed for cells that fall within this radius of a feature impacting scenic quality." +#: src/natcap/invest/scenic_quality/scenic_quality.py:158 +msgid "" +"Valuation will only be computed for cells that fall within this radius of" +" a feature impacting scenic quality." msgstr "只有在影响风景质量的特征的这个半径范围内的单元才会被计算出估值。" -#: src/natcap/invest/sdr/sdr.py:53 -msgid "Map of rainfall erosivity, reflecting the intensity and duration of rainfall in the area of interest." +#: src/natcap/invest/scenic_quality/scenic_quality.py:168 +msgid "Map of visual quality classified into quartiles." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:173 +msgid "" +"This raster layer contains the weighted sum of all visibility rasters. If" +" no weight column is provided in the structures point vector, this raster" +" will represent a count of the number of structure points that are " +"visible from each pixel." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:177 +msgid "" +"This raster layer contains the weighted sum of the valuation rasters " +"created for each point." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:186 +msgid "" +"This vector is the AOI, reprojected to the DEM’s spatial reference and " +"projection." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:191 +msgid "" +"This raster layer is a version of the DEM that has been clipped and " +"masked to the AOI and tiled. This is the DEM file that is used for the " +"viewshed analysis." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:195 +msgid "Copy of the structures vector, clipped to the AOI extent." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:201 +msgid "" +"Copy of the structures vector, reprojected to the DEM’s spatial reference" +" and projection." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:206 +msgid "" +"The calculated value of the viewshed amenity/disamenity given the " +"distances of pixels from the structure's viewpoint, the weight of the " +"viewpoint, the valuation function, and the a and b coefficients. The " +"viewshed’s value is only evaluated for visible pixels." +msgstr "" + +#: src/natcap/invest/scenic_quality/scenic_quality.py:210 +msgid "" +"Map of visibility for a given structure's viewpoint. This raster has " +"pixel values of 0 (not visible), 1 (visible), or nodata (where the DEM is" +" nodata)." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:54 +msgid "" +"Map of rainfall erosivity, reflecting the intensity and duration of " +"rainfall in the area of interest." msgstr "降雨侵蚀性地图,反映了有关地区的降雨强度和时间。" -#: src/natcap/invest/sdr/sdr.py:56 +#: src/natcap/invest/sdr/sdr.py:57 msgid "erosivity" msgstr "侵蚀性" -#: src/natcap/invest/sdr/sdr.py:64 -msgid "Map of soil erodibility, the susceptibility of soil particles to detachment and transport by rainfall and runoff." +#: src/natcap/invest/sdr/sdr.py:65 +msgid "" +"Map of soil erodibility, the susceptibility of soil particles to " +"detachment and transport by rainfall and runoff." msgstr "土壤侵蚀性地图,土壤颗粒容易被降雨和径流剥离和运输。" -#: src/natcap/invest/sdr/sdr.py:68 +#: src/natcap/invest/sdr/sdr.py:69 msgid "soil erodibility" msgstr "土壤侵蚀性" -#: src/natcap/invest/sdr/sdr.py:82 -msgid "Map of the boundaries of the watershed(s) over which to aggregate results. Each watershed should contribute to a point of interest where water quality will be analyzed." +#: src/natcap/invest/sdr/sdr.py:83 +msgid "" +"Map of the boundaries of the watershed(s) over which to aggregate " +"results. Each watershed should contribute to a point of interest where " +"water quality will be analyzed." msgstr "汇总结果的流域边界图。每一个流域都应该为一个兴趣点做出贡献,在那里将对水质进行分析。" -#: src/natcap/invest/sdr/sdr.py:86 +#: src/natcap/invest/sdr/sdr.py:87 msgid "Watersheds" msgstr "流域" -#: src/natcap/invest/sdr/sdr.py:94 +#: src/natcap/invest/sdr/sdr.py:96 msgid "Cover-management factor for the USLE" msgstr "USLE的覆盖管理系数" -#: src/natcap/invest/sdr/sdr.py:97 +#: src/natcap/invest/sdr/sdr.py:99 msgid "Support practice factor for the USLE" msgstr "支持USLE的实践因素" -#: src/natcap/invest/sdr/sdr.py:99 -msgid "A table mapping each LULC code to biophysical properties of that LULC class. All values in the LULC raster must have corresponding entries in this table." +#: src/natcap/invest/sdr/sdr.py:101 +msgid "" +"A table mapping each LULC code to biophysical properties of that LULC " +"class. All values in the LULC raster must have corresponding entries in " +"this table." msgstr "一个将每个LULC代码与该LULC类别的生物物理属性相匹配的表格。LULC栅格中的所有数值必须在此表中有相应的条目。" -#: src/natcap/invest/sdr/sdr.py:109 +#: src/natcap/invest/sdr/sdr.py:111 msgid "Borselli k parameter." msgstr "Borselli k参数。" -#: src/natcap/invest/sdr/sdr.py:114 +#: src/natcap/invest/sdr/sdr.py:116 msgid "The maximum SDR value that a pixel can have." msgstr "一个栅格可以拥有的最大SDR值。" -#: src/natcap/invest/sdr/sdr.py:115 +#: src/natcap/invest/sdr/sdr.py:117 msgid "maximum SDR value" msgstr "最大SDR值" -#: src/natcap/invest/sdr/sdr.py:120 +#: src/natcap/invest/sdr/sdr.py:122 msgid "Borselli IC0 parameter." msgstr "Borselli IC0参数。" -#: src/natcap/invest/sdr/sdr.py:121 +#: src/natcap/invest/sdr/sdr.py:123 msgid "Borselli IC0 parameter" msgstr "Borselli IC0参数" -#: src/natcap/invest/sdr/sdr.py:127 -msgid "The maximum allowed value of the slope length parameter (L) in the LS factor." +#: src/natcap/invest/sdr/sdr.py:129 +msgid "" +"The maximum allowed value of the slope length parameter (L) in the LS " +"factor." msgstr "LS因子中斜率长度参数(L)的最大允许值。" -#: src/natcap/invest/sdr/sdr.py:130 +#: src/natcap/invest/sdr/sdr.py:132 msgid "maximum l value" msgstr "最大l值" -#: src/natcap/invest/sdr/sdr.py:136 -msgid "Map of locations of artificial drainages that drain to the watershed. Pixels with 1 are drainages and are treated like streams. Pixels with 0 are not drainages." +#: src/natcap/invest/sdr/sdr.py:138 +msgid "" +"Map of locations of artificial drainages that drain to the watershed. " +"Pixels with 1 are drainages and are treated like streams. Pixels with 0 " +"are not drainages." msgstr "流入流域的人工排水沟位置图。带1的像素是排水沟,与溪流一样处理。带0的像素不是排水沟。" -#: src/natcap/invest/sdr/sdr.py:140 +#: src/natcap/invest/sdr/sdr.py:142 msgid "drainages" msgstr "排水渠" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:55 -msgid "Twelve files, one for each month. File names must end with the month number (1-12). For example, the filenames 'et0_1.tif' 'evapotranspiration1.tif' are both valid for the month of January." +#: src/natcap/invest/sdr/sdr.py:229 +#, fuzzy +msgid "" +"CP factor derived by mapping usle_c and usle_p from the biophysical table" +" to the LULC raster." +msgstr "将每个LULC代码从LULC映射到该LULC类的生物物理数据的表。" + +#: src/natcap/invest/sdr/sdr.py:235 +msgid "Downslope factor of the index of connectivity (Eq. (74))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:240 +msgid "Upslope factor of the index of connectivity (Eq. (73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:245 +msgid "" +"Sediment downslope deposition, the amount of sediment from a given pixel " +"that does not reach a stream (Eq. (78))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:254 +msgid "" +"Map of sediment flux for sediment that does not reach the stream (Eq. " +"(81))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:265 +msgid "Index of connectivity (Eq. (70))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:272 +msgid "LS factor for USLE (Eq. (69))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:280 +msgid "" +"Flow accumulation weighted by the thresholded slope. Used in calculating " +"s_bar." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:289 +msgid "" +"Mean thresholded slope gradient of the upslope contributing area (in eq. " +"(73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:298 +#, fuzzy +msgid "Sediment delivery ratio (Eq. (75))" +msgstr "泥沙输移比" + +#: src/natcap/invest/sdr/sdr.py:303 +msgid "" +"Percent slope, thresholded to be no less than 0.005 and no greater than 1" +" (eq. (71)). 1 is equivalent to a 45 degree slope." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:310 +msgid "" +"Flow accumulation weighted by the thresholded cover-management factor. " +"Used in calculating w_bar." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:319 +msgid "" +"Mean thresholded cover-management factor for upslope contributing area " +"(in eq. (73))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:325 +msgid "" +"Cover-management factor derived by mapping usle_c from the biophysical " +"table to the LULC raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:331 +msgid "Cover-management factor thresholded to be no less than 0.001 (eq. (72))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:337 +msgid "Average aspect weighted by flow direction (in eq. (69))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:342 +msgid "" +"Map of which pixels drain to a stream. A value of 1 means that at least " +"some of the runoff from that pixel drains to a stream in stream.tif. A " +"value of 0 means that it does not drain at all to any stream in " +"stream.tif." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:351 +msgid "" +"Inverse of the thresholded cover-management factor times the thresholded " +"slope (in eq. (74))" +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:357 +msgid "Copy of the input DEM, clipped to the extent of the other raster inputs." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:366 +msgid "" +"Copy of the input drainage map, clipped to the extent of the other raster" +" inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:373 +msgid "" +"Copy of the input erodibility map, clipped to the extent of the other " +"raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:383 +msgid "" +"Copy of the input erosivity map, clipped to the extent of the other " +"raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:393 +msgid "" +"Copy of the input Land Use Land Cover map, clipped to the extent of the " +"other raster inputs and aligned to the DEM." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:400 +msgid "" +"A raster aligned to the DEM and clipped to the extent of the other raster" +" inputs. Pixel values indicate where a nodata value exists in the stack " +"of aligned rasters (pixel value of 0), or if all values in the stack of " +"rasters at this pixel location are valid." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:410 +msgid "A copy of the aligned DEM, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:418 +msgid "A copy of the aligned drainage map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:425 +msgid "A copy of the aligned erodibility map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:435 +msgid "A copy of the aligned erosivity map, masked using the mask raster." +msgstr "" + +#: src/natcap/invest/sdr/sdr.py:444 +msgid "" +"A copy of the aligned Land Use Land Cover map, masked using the mask " +"raster." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:53 +msgid "" +"Twelve files, one for each month. File names must end with the month " +"number (1-12). For example, the filenames 'et0_1.tif' " +"'evapotranspiration1.tif' are both valid for the month of January." msgstr "12个文件,每个月一个。文件名必须以月份编号(1-12)结尾。例如,文件名'et0_1.tif''evapotranspiration1.tif'都对1月份有效。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:64 -msgid "Directory containing maps of reference evapotranspiration for each month. Only .tif files should be in this folder (no .tfw, .xml, etc files)." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:62 +msgid "" +"Directory containing maps of reference evapotranspiration for each month." +" Only .tif files should be in this folder (no .tfw, .xml, etc files)." msgstr "包含每个月的参考蒸发量地图的目录。在这个文件夹中只有.tif文件(没有.tfw、.xml等文件)。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:68 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:66 msgid "ET0 directory" msgstr "模型数据目录" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:76 -msgid "Twelve files, one for each month. File names must end with the month number (1-12). For example, the filenames 'precip_1.tif' and 'precip1.tif' are both valid names for the month of January." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:74 +msgid "" +"Twelve files, one for each month. File names must end with the month " +"number (1-12). For example, the filenames 'precip_1.tif' and " +"'precip1.tif' are both valid names for the month of January." msgstr "12个文件,每个月一个。文件名必须以月号(1-12)结尾。例如,文件名'precip_1.tif'和'precip1.tif'都是一月的有效名称。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:84 -msgid "Directory containing maps of monthly precipitation for each month. Only .tif files should be in this folder (no .tfw, .xml, etc files)." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:82 +msgid "" +"Directory containing maps of monthly precipitation for each month. Only " +".tif files should be in this folder (no .tfw, .xml, etc files)." msgstr "包含每个月的月度降水量地图的目录。在这个文件夹中只能有.tif文件(没有.tfw、.xml等文件)。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:88 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:86 msgid "precipitation directory" msgstr "降水目录" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:97 -msgid "All values in this raster MUST have corresponding entries in the Biophysical Table." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:95 +msgid "" +"All values in this raster MUST have corresponding entries in the " +"Biophysical Table." msgstr "该栅格中的所有数值必须在生物物理表中有相应的条目。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:117 -msgid "Curve number values for each combination of soil group and LULC class. Replace [SOIL_GROUP] with each soil group code A, B, C, D so that there is one column for each soil group. Curve number values must be greater than 0." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:116 +msgid "" +"Curve number values for each combination of soil group and LULC class. " +"Replace [SOIL_GROUP] with each soil group code A, B, C, D so that there " +"is one column for each soil group. Curve number values must be greater " +"than 0." msgstr "土壤组和LULC等级的每个组合的曲线数值。用每个土壤组的代码A、B、C、D替换[SOIL_GROUP],这样每个土壤组就有一列。曲线编号值必须大于0。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:127 -msgid "Crop/vegetation coefficient (Kc) values for this LULC class in each month. Replace [MONTH] with the numbers 1 to 12 so that there is one column for each month." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:126 +msgid "" +"Crop/vegetation coefficient (Kc) values for this LULC class in each " +"month. Replace [MONTH] with the numbers 1 to 12 so that there is one " +"column for each month." msgstr "该LULC等级在每个月的作物/植被系数(Kc)值。用数字1至12代替[MONTH],这样每个月就有一列。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:134 -msgid "A table mapping each LULC code to biophysical properties of the corresponding LULC class. All values in the LULC raster must have corresponding entries in this table." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:133 +msgid "" +"A table mapping each LULC code to biophysical properties of the " +"corresponding LULC class. All values in the LULC raster must have " +"corresponding entries in this table." msgstr "将每个LULC代码与相应的LULC类别的生物物理属性进行映射的表格。LULC栅格中的所有数值必须在此表中有相应的条目。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:146 -msgid "Values are the numbers 1-12 corresponding to each month, January (1) through December (12)." +msgid "" +"Values are the numbers 1-12 corresponding to each month, January (1) " +"through December (12)." msgstr "数值为1-12的数字,对应每个月,1月(1)到12月(12)。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:153 @@ -3013,7 +4597,10 @@ msgid "The number of rain events in that month." msgstr "该月的雨水事件的数量。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:159 -msgid "A table containing the number of rain events for each month. Required if neither User-Defined Local Recharge nor User-Defined Climate Zones is selected." +msgid "" +"A table containing the number of rain events for each month. Required if " +"neither User-Defined Local Recharge nor User-Defined Climate Zones is " +"selected." msgstr "一个包含每个月雨量事件数量的表格。如果既没有选择用户定义的本地补给,也没有选择用户定义的气候区,则需要。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:163 @@ -3021,7 +4608,10 @@ msgid "rain events table" msgstr "降雨事件表" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:168 -msgid "The proportion of upslope annual available local recharge that is available in each month. Required if Use Monthly Alpha Table is not selected." +msgid "" +"The proportion of upslope annual available local recharge that is " +"available in each month. Required if Use Monthly Alpha Table is not " +"selected." msgstr "每个月的上坡年可用本地补给量的比例。如果不选择使用月度阿尔法表,则需要。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:172 @@ -3029,7 +4619,9 @@ msgid "alpha_m parameter" msgstr "alpha_m 参数" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:176 -msgid "The proportion of the upgradient subsidy that is available for downgradient evapotranspiration." +msgid "" +"The proportion of the upgradient subsidy that is available for " +"downgradient evapotranspiration." msgstr "可用于下流蒸发的上流补给的比例。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:179 @@ -3037,7 +4629,9 @@ msgid "beta_i parameter" msgstr "beta_i 参数" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:183 -msgid "The proportion of pixel local recharge that is available to downgradient pixels." +msgid "" +"The proportion of pixel local recharge that is available to downgradient " +"pixels." msgstr "下游栅格可获得的栅格本地补给比例。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:186 @@ -3045,7 +4639,9 @@ msgid "gamma parameter" msgstr "gamma参数" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:190 -msgid "Use user-defined local recharge data instead of calculating local recharge from the other provided data." +msgid "" +"Use user-defined local recharge data instead of calculating local " +"recharge from the other provided data." msgstr "使用用户定义的本地补给数据,而不是根据其他提供的数据计算本地补给。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:193 @@ -3053,7 +4649,9 @@ msgid "user-defined recharge layer (advanced)" msgstr "用户定义的补给层(高级)" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:203 -msgid "Map of local recharge data. Required if User-Defined Local Recharge is selected." +msgid "" +"Map of local recharge data. Required if User-Defined Local Recharge is " +"selected." msgstr "本地补给数据的地图。如果选择用户定义的本地补给,则需要。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:206 @@ -3068,61 +4666,223 @@ msgstr "使用用户定义的气候区数据来代替全球雨水事件表。" msgid "climate zones (advanced)" msgstr "气候区(高级)" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:220 -msgid "Climate zone ID numbers, corresponding to the values in the Climate Zones map." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:221 +msgid "" +"Climate zone ID numbers, corresponding to the values in the Climate Zones" +" map." msgstr "气候区ID号,与气候区地图中的数值相对应。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:226 -msgid "The number of rain events that occur in each month in this climate zone. Replace [MONTH] with the month abbreviations: jan, feb, mar, apr, may, jun, jul, aug, sep, oct, nov, dec, so that there is a column for each month." -msgstr "该气候区每月发生的雨量事件的数量。将[MONTH]改为月份缩写:Jan, feb, mar, apr, may, jun, jul, aug, sep, oct, nov, dec,这样,每个月都有一列。" +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:227 +msgid "" +"The number of rain events that occur in each month in this climate zone. " +"Replace [MONTH] with the month abbreviations: jan, feb, mar, apr, may, " +"jun, jul, aug, sep, oct, nov, dec, so that there is a column for each " +"month." +msgstr "" +"该气候区每月发生的雨量事件的数量。将[MONTH]改为月份缩写:Jan, feb, mar, apr, may, jun, jul, aug, " +"sep, oct, nov, dec,这样,每个月都有一列。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:234 -msgid "Table of monthly precipitation events for each climate zone. Required if User-Defined Climate Zones is selected." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:235 +msgid "" +"Table of monthly precipitation events for each climate zone. Required if " +"User-Defined Climate Zones is selected." msgstr "每个气候区的月降水事件表。如果选择了“自定义气候区”,则需要。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:237 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:238 msgid "climate zone table" msgstr "气候区表" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:244 -msgid "Map of climate zones. All values in this raster must have corresponding entries in the Climate Zone Table." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:245 +msgid "" +"Map of climate zones. All values in this raster must have corresponding " +"entries in the Climate Zone Table." msgstr "气候区地图。该栅格中的所有值必须在气候区表中有相应的条目。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:247 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:248 msgid "climate zone map" msgstr "气候区地图" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:251 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:252 msgid "Use montly alpha values instead of a single value for the whole year." msgstr "使用每月alpha值,而不是全年的单一值。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:254 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:255 msgid "use monthly alpha table (advanced)" msgstr "使用月alpha表(高级)" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:262 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:264 msgid "Values are the numbers 1-12 corresponding to each month." msgstr "值是与每个月对应的数字1-12。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:269 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:271 msgid "The alpha value for that month." msgstr "该月的alpha值。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:273 -msgid "Table of alpha values for each month. Required if Use Monthly Alpha Table is selected." +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:275 +msgid "" +"Table of alpha values for each month. Required if Use Monthly Alpha Table" +" is selected." msgstr "每个月的alpha值表。如果选中“使用月Alpha表”,则需要。" -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:276 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:278 msgid "monthly alpha table" msgstr "月alpha表" +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:283 +msgid "" +"Map of baseflow values, the contribution of a pixel to slow release flow " +"(which is not evapotranspired before it reaches the stream)." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:293 +msgid "" +"Map of B_sum values, the flow through a pixel, contributed by all upslope" +" pixels, that is not evapotranspirated before it reaches the stream." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:303 +#, fuzzy +msgid "Map of curve number values." +msgstr "道路中心线地图" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:310 +#, fuzzy +msgid "Map of available local recharge" +msgstr "本地补给" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:317 +#, fuzzy +msgid "Map of local recharge values" +msgstr "本地补给" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:324 +msgid "" +"Map of total available water, contributed by all upslope pixels, that is " +"available for evapotranspiration by this pixel." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:333 +msgid "" +"Map of cumulative upstream recharge: the flow through a pixel, " +"contributed by all upslope pixels, that is available for " +"evapotranspiration to downslope pixels." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:343 +msgid "Map of quickflow" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:350 +msgid "The total precipitation across all months on this pixel." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:357 +msgid "" +"Map of the values of recharge (contribution, positive or negative), to " +"the total recharge." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:366 +#, fuzzy +msgid "Table of biophysical values for each watershed" +msgstr "每个LULC类别的生物物理特性表。" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:370 +msgid "Mean local recharge value within the watershed" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:376 +msgid "Total recharge contribution, (positive or negative) within the watershed." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:388 +#, fuzzy +msgid "Map of actual evapotranspiration" +msgstr "蒸发量值地图。" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:395 +msgid "" +"Map of multiple flow direction. Values are encoded in a binary format and" +" should not be used directly." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:401 +msgid "Maps of monthly quickflow (1 = January… 12 = December)" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:409 +msgid "" +"Stream network map generated from the input DEM and Threshold Flow " +"Accumulation. Values of 1 represent streams, values of 0 are non-stream " +"pixels." +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:418 +msgid "Map of the S_i factor derived from CN" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:422 +msgid "Copy of LULC input, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:427 +msgid "Copy of DEM input, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:432 +msgid "Pit filled DEM" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:436 +msgid "" +"Copy of soil groups input, aligned and clipped to match the other spatial" +" inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:443 +msgid "" +"Monthly precipitation rasters, aligned and clipped to match the other " +"spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:447 +msgid "Map of monthly rain events" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:452 +msgid "Monthly ET0 rasters, aligned and clipped to match the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:456 +msgid "Map of monthly KC values" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:460 +msgid "" +"Copy of user-defined local recharge input, aligned and clipped to match " +"the other spatial inputs" +msgstr "" + +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:465 +msgid "" +"Copy of user-defined climate zones raster, aligned and clipped to match " +"the other spatial inputs" +msgstr "" + #~ msgid "LULC code corresponding to values in the LULC map." #~ msgstr "与LULC栅格中的值相对应的LULC代码。" -#~ msgid "LULC code. Every value in the LULC maps must have a corresponding entry in this column." +#~ msgid "" +#~ "LULC code. Every value in the LULC" +#~ " maps must have a corresponding entry" +#~ " in this column." #~ msgstr "LULC代码。LULC地图中的每一个值都必须在这一栏中有一个相应的条目。" -#~ msgid "Code for this LULC class from the LULC map. Every value in the LULC raster must have a corresponding entry in this column." +#~ msgid "" +#~ "Code for this LULC class from the" +#~ " LULC map. Every value in the " +#~ "LULC raster must have a corresponding" +#~ " entry in this column." #~ msgstr "从LULC中对应是代码。LULC栅格中的每个值在这一列中都必须有相应的条目。" #~ msgid "Use the predefined GLOBIO LULC map instead of providing the LULC map." @@ -3131,7 +4891,11 @@ msgstr "月alpha表" #~ msgid "use predefined LULC" #~ msgstr "使用预定义的LULC" -#~ msgid "Each LULC code must have a corresponding entry in the biophysical table. Required if Use Predefined GLOBIO LULC is not selected." +#~ msgid "" +#~ "Each LULC code must have a " +#~ "corresponding entry in the biophysical " +#~ "table. Required if Use Predefined GLOBIO" +#~ " LULC is not selected." #~ msgstr "每个LULC代码必须在生物物理表中有一个相应的条目。如果不选择使用预定义GLOBIO LULC,则需要。" #~ msgid "LULC code from the LULC map input." @@ -3140,22 +4904,42 @@ msgstr "月alpha表" #~ msgid "Corresponding GLOBIO LULC code." #~ msgstr "相应的GLOBIO LULC代码。" -#~ msgid "A table mapping each LULC code in the LULC raster input to the corresponding GLOBIO LULC code for the class. Required if Use Predefined GLOBIO LULC is not selected." -#~ msgstr "将LULC栅格输入中的每个LULC代码映射到该类的相应GLOBIO LULC代码的表格。如果没有选择使用预定义的GLOBIO LULC,则需要。" +#~ msgid "" +#~ "A table mapping each LULC code in" +#~ " the LULC raster input to the " +#~ "corresponding GLOBIO LULC code for the" +#~ " class. Required if Use Predefined " +#~ "GLOBIO LULC is not selected." +#~ msgstr "" +#~ "将LULC栅格输入中的每个LULC代码映射到该类的相应GLOBIO LULC代码的表格。如果没有选择使用预定义的GLOBIO" +#~ " LULC,则需要。" #~ msgid "LULC to GLOBIO LULC Table" #~ msgstr "LULC与GLOBIO LULC对应表" -#~ msgid "Maps of the location of infrastructure. For rasters, any valid value greater than zero indicates the presence of infrastrucutre. For vectors, any geometries indicate the presence of infrastructure." +#~ msgid "" +#~ "Maps of the location of infrastructure." +#~ " For rasters, any valid value greater" +#~ " than zero indicates the presence of" +#~ " infrastrucutre. For vectors, any " +#~ "geometries indicate the presence of " +#~ "infrastructure." #~ msgstr "基础设施位置的地图。对于栅格,任何大于零的有效值都表示有基础设施存在。对于矢量,任何几何图形都表示有基础设施存在。" -#~ msgid "Directory containing raster and/or vector map(s) any forms of infrastructure to consider in the MSA calculation." +#~ msgid "" +#~ "Directory containing raster and/or vector " +#~ "map(s) any forms of infrastructure to" +#~ " consider in the MSA calculation." #~ msgstr "包含栅格和/或矢量地图的目录,在MSA计算中考虑的任何形式的基础设施。" #~ msgid "infrastructure directory" #~ msgstr "基础设施目录" -#~ msgid "Map of the proportion of each pixel that is pasture. Required if Use Predefined GLOBIO LULC is not selected." +#~ msgid "" +#~ "Map of the proportion of each " +#~ "pixel that is pasture. Required if " +#~ "Use Predefined GLOBIO LULC is not " +#~ "selected." #~ msgstr "每个栅格的牧草比例图。如果不选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "pasture" @@ -3164,10 +4948,20 @@ msgstr "月alpha表" #~ msgid "potential vegetation" #~ msgstr "潜在的植被" -#~ msgid "Map of potential vegetation classes from Ramankutty and Foley (1999). Required if Use Predefined GLOBIO LULC is not selected." +#~ msgid "" +#~ "Map of potential vegetation classes from" +#~ " Ramankutty and Foley (1999). Required " +#~ "if Use Predefined GLOBIO LULC is " +#~ "not selected." #~ msgstr "来自Ramankutty和Foley(1999)的潜在植被等级图。如果不选择使用预定义的GLOBIO LULC,则需要。" -#~ msgid "Areas in the Pasture map with a pasture proportion greater than or equal to this threshold are considered grassland or livestock grazing areas. Required if Use Predefined GLOBIO LULC is not selected." +#~ msgid "" +#~ "Areas in the Pasture map with a" +#~ " pasture proportion greater than or " +#~ "equal to this threshold are considered" +#~ " grassland or livestock grazing areas. " +#~ "Required if Use Predefined GLOBIO LULC" +#~ " is not selected." #~ msgstr "牧场地图中牧场比例大于或等于该阈值的区域被视为草原或牲畜放牧区。如果不选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "pasture threshold" @@ -3179,40 +4973,82 @@ msgstr "月alpha表" #~ msgid "proportion of intensified agriculture" #~ msgstr "强化农业的比例" -#~ msgid "Forest ragmentation quality index threshold below which an area is classified as secondary forest. Areas with FFQI greater than or equal to this threshold are classified as primary forest. Required if Use Predefined GLOBIO LULC is not selected." -#~ msgstr "森林破损质量指数阈值,低于此阈值的区域被归类为次生林。FFQI大于或等于该阈值的区域被划为原始森林。如果不选择使用预定义的GLOBIO LULC,则需要。" +#~ msgid "" +#~ "Forest ragmentation quality index threshold" +#~ " below which an area is classified" +#~ " as secondary forest. Areas with FFQI" +#~ " greater than or equal to this " +#~ "threshold are classified as primary " +#~ "forest. Required if Use Predefined " +#~ "GLOBIO LULC is not selected." +#~ msgstr "" +#~ "森林破损质量指数阈值,低于此阈值的区域被归类为次生林。FFQI大于或等于该阈值的区域被划为原始森林。如果不选择使用预定义的GLOBIO" +#~ " LULC,则需要。" #~ msgid "primary threshold" #~ msgstr "主要阈值" -#~ msgid "This MSA value represents infrastructure impacts on primary vegetation. The value in the 'value' column is a distance range in meters." +#~ msgid "" +#~ "This MSA value represents infrastructure " +#~ "impacts on primary vegetation. The value" +#~ " in the 'value' column is a " +#~ "distance range in meters." #~ msgstr "该MSA值表示基础设施对初级植被的影响。“value”列中的值是以米为单位的距离范围。" -#~ msgid "This MSA value represents infrastructure impacts on non-primary vegetation. The value in the 'value' column is a distance range in meters." +#~ msgid "" +#~ "This MSA value represents infrastructure " +#~ "impacts on non-primary vegetation. The" +#~ " value in the 'value' column is " +#~ "a distance range in meters." #~ msgstr "该MSA值表示基础设施对非原生植被的影响。“value”列中的值是以米为单位的距离范围。" -#~ msgid "This MSA value represents fragmentation impacts. The value in the 'value' column is an FFQI range." +#~ msgid "" +#~ "This MSA value represents fragmentation " +#~ "impacts. The value in the 'value' " +#~ "column is an FFQI range." #~ msgstr "这个MSA值表示碎片影响。“value”列中的值是一个FFQI范围。" -#~ msgid "This MSA value represents land-use impacts. The value in the 'value' column is one of the GLOBIO-recognized LULC codes." +#~ msgid "" +#~ "This MSA value represents land-use " +#~ "impacts. The value in the 'value' " +#~ "column is one of the GLOBIO-" +#~ "recognized LULC codes." #~ msgstr "这个MSA值表示土地使用的影响。“value”列中的值是GLOBIO识别的LULC代码之一。" #~ msgid "The type of MSA value in this row." #~ msgstr "该行中MSA值的类型。" -#~ msgid "Indicates a number or range of a bin. This may be a single number e.g. 1000, a range (two numbers separated by a hyphen e.g. 1000-2000), or an upper or lower bound (a number preceded by > or < e.g. <5" +#~ msgid "" +#~ "Indicates a number or range of a" +#~ " bin. This may be a single " +#~ "number e.g. 1000, a range (two " +#~ "numbers separated by a hyphen e.g. " +#~ "1000-2000), or an upper or lower " +#~ "bound (a number preceded by > or" +#~ " < e.g. <5" #~ msgstr "表示一个数字或一个bin的范围。这可以是一个单一的数字,如1000,一个范围(用连字符分隔的两个数字,如1000-2000),或一个上界或下界(前面有>或<的数字,如:<5" -#~ msgid "MSA value for the MSA type specified in the 'msa_type' column, when the impact value is within the range given in the 'value' column." +#~ msgid "" +#~ "MSA value for the MSA type " +#~ "specified in the 'msa_type' column, when" +#~ " the impact value is within the " +#~ "range given in the 'value' column." #~ msgstr "在'msa_type'列中指定的MSA类型的MSA值,当影响值在'value'列中给出的范围内。" -#~ msgid "Table that sets the MSA values for each impact driver and each range of impact values." +#~ msgid "" +#~ "Table that sets the MSA values for" +#~ " each impact driver and each range" +#~ " of impact values." #~ msgstr "为每个冲击器和每个冲击值范围设定MSA值的表格。" #~ msgid "MSA Parameter Table" #~ msgstr "MSA参数表" -#~ msgid "Predefined GLOBIO LULC map using the standard GLOBIO classification scheme and codes. Required if Use Predefined GLOBIO LULC is selected." +#~ msgid "" +#~ "Predefined GLOBIO LULC map using the " +#~ "standard GLOBIO classification scheme and " +#~ "codes. Required if Use Predefined GLOBIO" +#~ " LULC is selected." #~ msgstr "使用标准GLOBIO分类方案和代码的预定义GLOBIO LULC地图。如果选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "GLOBIO Classified Land Use" @@ -3268,3 +5104,85 @@ msgstr "月alpha表" #~ msgid "MULTIPOLYGON" #~ msgstr "多边形集" + +#~ msgid "very high protection" +#~ msgstr "极高的保护" + +#~ msgid "high protection" +#~ msgstr "高度保护" + +#~ msgid "moderate protection" +#~ msgstr "中度保护" + +#~ msgid "low protection" +#~ msgstr "低保护" + +#~ msgid "very low protection" +#~ msgstr "极低保护" + +#~ msgid "" +#~ "The column '{column_name}' was not found" +#~ " in the Threat Data table for " +#~ "the corresponding input LULC scenario." +#~ msgstr "在相应的输入LULC情景的威胁数据表中没有找到\"{column_name}\"列。" + +#~ msgid "" +#~ "Map of the threat's distribution in " +#~ "the future scenario. Each pixel value" +#~ " is the relative intensity of the " +#~ "threat at that location. Required if " +#~ "Future LULC is provided." +#~ msgstr "威胁在未来场景中的分布图。每个像素值都是该位置威胁的相对强度。如果提供未来LULC,则必须。" + +#~ msgid "File could not be opened as a CSV or Excel file." +#~ msgstr "文件无法作为CSV或Excel文件打开。" + +#~ msgid "File could not be opened as a CSV. File must be encoded as a UTF-8 CSV." +#~ msgstr "文件不能以CSV形式打开。文件必须被编码为UTF-8 CSV。" + +#~ msgid "Bounding boxes do not intersect: {bboxes}" +#~ msgstr "边界不相交:{bboxes} 。" + +#~ msgid "Maximum capacity for device." +#~ msgstr "设备的最大容量。" + +#~ msgid "" +#~ "Upper limit of wave height for " +#~ "device operation. The device shuts down" +#~ " when waves are higher than this." +#~ msgstr "设备运行的波浪高度的上限。当波浪高于这个高度时,设备就会关闭。" + +#~ msgid "" +#~ "Upper limit of wave period for " +#~ "device operation. The device shuts down" +#~ " when the wave period is longer " +#~ "than this." +#~ msgstr "设备运行的波形周期的上限。当波浪周期长于此值时,设备就会关闭。" + +#~ msgid "Maximum capacity of the device." +#~ msgstr "设备的最大容量。" + +#~ msgid "Capital cost per device installed." +#~ msgstr "每套设备的资本成本。" + +#~ msgid "Cost of mooring lines." +#~ msgstr "停泊线的费用。" + +#~ msgid "Cost of underwater cable." +#~ msgstr "水下电缆的成本。" + +#~ msgid "Cost of overland transmission lines." +#~ msgstr "陆上输电线路的成本。" + +#~ msgid "Operating and maintenance cost." +#~ msgstr "运营和维护成本。" + +#~ msgid "Price of electricity." +#~ msgstr "电价。" + +#~ msgid "Discount rate." +#~ msgstr "折扣率。" + +#~ msgid "Number of slack lines required per machine." +#~ msgstr "每台机器需要的松弛线的数量。" + From 58d33f0b32d2fc14f5ae46150ebe9272cb2d9e1f Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 25 Mar 2024 14:00:22 -0700 Subject: [PATCH 06/90] add new messages into zh translation files --- workbench/src/renderer/i18n/zh.json | 55 +++++++++++++++++++---------- 1 file changed, 36 insertions(+), 19 deletions(-) diff --git a/workbench/src/renderer/i18n/zh.json b/workbench/src/renderer/i18n/zh.json index 2453983dd8..aa2c219167 100644 --- a/workbench/src/renderer/i18n/zh.json +++ b/workbench/src/renderer/i18n/zh.json @@ -1,4 +1,5 @@ { + "Please choose a different folder. This application does not have permission to write to folder:": "", "Download InVEST sample data": "下载InVEST样例数据", "Cancel": "取消", "Download": "下载", @@ -21,6 +22,7 @@ "Cancel Run": "取消运行", "Error: see log for details": "错误:详见日志", "Run Canceled": "取消运行", + "No InVEST model data can be parsed from the file:": "", "Browse to a datastack (.json) or InVEST logfile (.txt)": "浏览到一个数据包(.json)或InVEST日志文件(.txt)。", "Open": "打开", "User's Guide": "用户指南", @@ -40,24 +42,39 @@ "ERROR": "错误", "InVEST Settings": "InVEST设置", "Language": "语言", - "Changing this setting will refresh the app and close all tabs": "更改此设置将刷新应用程序并关闭所有选项卡", "Logging threshold": "日志阈值", "Taskgraph logging threshold": "任务图记录阈值", + "Taskgraph n_workers parameter": "任务图n_workers参数", "more info": "更多信息", "synchronous task execution is most reliable": "同步任务的执行是最可靠的", "threaded task management: tasks execute only in the main process, using multiple threads.": "线程任务管理:任务只在主进程中使用多线程执行。", "n CPUs: depending on the InVEST model, tasks may execute in parallel using up to this many processes.": "n CPU:根据 InVEST 模型,任务最多可以在这么多个进程下执行任务。", - "Reset to Defaults": "重置为默认值", "Download Sample Data": "下载样例数据", "Clear Recent Jobs": "清除最近的工作", "no invest workspaces will be deleted": "没有invest的工作空间将被删除", - "Bounding box does not intersect at least one other:": "边界框至少不与另一个相交:", + "Warning": "", + "Changing this setting will close your tabs and relaunch the app.": "", + "Change to ": "", + "Not all of the spatial layers overlap each other. Bounding box:": "", "optional": "可选项", + "boolean": "", + "integer": "整数", + "csv": "", + "directory": "模型数据目录", + "file": "文件后缀", + "freestyle_string": "", + "number": "数量", + "option_string": "", + "percent": "百分比", + "raster": "栅格", + "ratio": "比例", + "vector": "向量", "text": "文本", "percent: a number from 0 - 100": "百分比:一个从0-100的数字", "ratio: a decimal from 0 - 1": "比率:一个从0-1的小数", "User's guide entry": "用户指南条目", "Only drop one file at a time.": "一次只能丢一个文件。", + "Choose location to extract archive": "", "Datastack/Logfile for {{modelName}} does not match this model.": "{{modelName}} 个数据堆栈/日志文件与此模型不匹配。", "Running": "运行中", "Run": "运行", @@ -65,11 +82,12 @@ "Load parameters from file": "从文件中加载参数", "No args to see here": "在args dict中缺少关键信息", "version:": "版本:", - "Copyright 2022, The Natural Capital Project": "版权所有 2022, The Natural Capital Project", - "Documentation: ": "文档:", - "Homepage: ": "主页:", - "Project page: ": "项目页面:", - "License: ": "许可证:", + "Copyright 2023, The Natural Capital Project": "", + "Documentation": "", + "Homepage": "", + "Project page": "", + "License": "", + "InVEST Trademark and Logo Use Policy": "", "Open-Source Licenses:": "开源许可证:", "MIT and others": "MIT许可证及其他许可证", "Please help us by reporting problems.": "请通过报告问题来帮助我们。", @@ -81,6 +99,14 @@ "Consider taking a screenshot of the problem.": "请截屏保存以便随后发布帖子寻求帮助。", "Find the log files using the button below. There may be multiple files with a \".log\" extension; please include them all.": "使用下面的按钮查找日志文件。 可能有多个扩展名为“.log”的文件; 请把它们全部包括在内。", "Create a post on our forum and upload these items, along with a brief description of the problem.": "在我们的论坛上创建一个帖子并上传这些项目以及问题的简要说明。", + "Changing this setting will refresh the app and close all tabs": "更改此设置将刷新应用程序并关闭所有选项卡", + "Reset to Defaults": "重置为默认值", + "Bounding box does not intersect at least one other:": "边界框至少不与另一个相交:", + "Copyright 2022, The Natural Capital Project": "版权所有 2022, The Natural Capital Project", + "Documentation: ": "文档:", + "Homepage: ": "主页:", + "Project page: ": "项目页面:", + "License: ": "许可证:", "Export all input data to a compressed archive": "将所有输入数据导出到压缩档案中", "InVEST": "InVEST", "Save datastack": "保存数据包", @@ -90,14 +116,5 @@ "Save to Python script": "保存到Python脚本", "true/false": "真/假", "CSV": "CSV", - "directory": "模型数据目录", - "file": "文件后缀", - "integer": "整数", - "number": "数量", - "option": "选项", - "percent": "百分比", - "raster": "栅格", - "ratio": "比例", - "vector": "向量", - "Taskgraph n_workers parameter": "任务图n_workers参数" -} \ No newline at end of file + "option": "选项" +} From 59ecd73a7e564f56b2b97865d6d6420b562d2aef Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 25 Mar 2024 14:01:15 -0700 Subject: [PATCH 07/90] minor updates to invest translation readme --- src/natcap/invest/internationalization/README.md | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/natcap/invest/internationalization/README.md b/src/natcap/invest/internationalization/README.md index 37a4b9c205..5a66ea0ab1 100644 --- a/src/natcap/invest/internationalization/README.md +++ b/src/natcap/invest/internationalization/README.md @@ -27,7 +27,8 @@ When we are ready to get a new batch of translations, here is the process. These pybabel extract \ --no-wrap \ --project InVEST \ - --msgid-bugs-address esoth@stanford.edu \ + --version $(python -m setuptools_scm) \ + --msgid-bugs-address natcap-software@lists.stanford.edu \ --copyright-holder "Natural Capital Project" \ --output src/natcap/invest/internationalization/messages.pot \ src/ @@ -38,6 +39,7 @@ pybabel update \ --input-file src/natcap/invest/internationalization/messages.pot \ --output-file src/natcap/invest/internationalization/locales/$LL/LC_MESSAGES/messages.po ``` +This looks through the source code for strings wrapped in the `gettext(...)` function and writes them to the message catalog template. Then it updates the message catalog for the specificed language. New strings that don't yet have a translation will have an empty `msgstr` value. Previously translated messages that are no longer needed will be commented out but remain in the file. This will save translator time if they're needed again in the future. 2. Check that the changes look correct, then commit: ``` @@ -45,7 +47,6 @@ git diff git add src/natcap/invest/internationalization/messages.pot src/natcap/invest/internationalization/locales/$LL/LC_MESSAGES/messages.po git commit -m "extract message catalog template and update $LL catalog from it" ``` -This looks through the source code for strings wrapped in the `gettext(...)` function and writes them to the message catalog template. Then it updates the message catalog for the specificed language. New strings that don't yet have a translation will have an empty `msgstr` value. Previously translated messages that are no longer needed will be commented out but remain in the file. This will save translator time if they're needed again in the future. 3. Send `src/natcap/invest/internationalization/locales/$LL/LC_MESSAGES/messages.po` to the translator and wait to get it back. The translator will fill in the `msgstr` values for any new or edited messages. From f9a3fd54ae080d4a1587c8cad796c20a5b13687f Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 26 Mar 2024 09:28:46 -0700 Subject: [PATCH 08/90] extract message catalog template and update zh catalog from it --- .../internationalization/locales/zh/LC_MESSAGES/messages.po | 2 +- src/natcap/invest/internationalization/messages.pot | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po b/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po index 3af5c611b4..f32207e79a 100644 --- a/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po +++ b/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: InVEST 3.12\n" "Report-Msgid-Bugs-To: jdouglass@stanford.edu\n" -"POT-Creation-Date: 2024-03-25 13:25-0700\n" +"POT-Creation-Date: 2024-03-26 09:24-0700\n" "PO-Revision-Date: 2023-03-16 14:02-0700\n" "Last-Translator: \n" "Language: zh\n" diff --git a/src/natcap/invest/internationalization/messages.pot b/src/natcap/invest/internationalization/messages.pot index 720b480c54..4a178416d1 100644 --- a/src/natcap/invest/internationalization/messages.pot +++ b/src/natcap/invest/internationalization/messages.pot @@ -6,9 +6,9 @@ #, fuzzy msgid "" msgstr "" -"Project-Id-Version: InVEST 3.14.1.post110+g0223b0d05.d20240325\n" -"Report-Msgid-Bugs-To: natcap-software@lists.stanford.edu\n" -"POT-Creation-Date: 2024-03-25 13:25-0700\n" +"Project-Id-Version: InVEST VERSION\n" +"Report-Msgid-Bugs-To: esoth@stanford.edu\n" +"POT-Creation-Date: 2024-03-26 09:24-0700\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" From 1f78fef949403c50ec530a76e700129c9994c5e5 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 26 Mar 2024 11:40:23 -0700 Subject: [PATCH 09/90] minor updates to workbench translation docs --- workbench/readme.md | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/workbench/readme.md b/workbench/readme.md index 958bc96797..c5e3893d63 100644 --- a/workbench/readme.md +++ b/workbench/readme.md @@ -121,18 +121,24 @@ These instructions assume you have defined the two-letter locale code in an envi git add src/main/i18n/$LL.json src/renderer/i18n/$LL.json git commit -m "add new messages into $LL translation files" ``` -3. (if the translator uses PO format) Convert JSON to PO +3. Convert JSON to PO using [i18next-gettext-converter](https://github.com/i18next/i18next-gettext-converter): + ``` + i18next-conv -l $LL -s src/main/i18n/$LL.json -t src/main/i18n/$LL.po + i18next-conv -l $LL -s src/renderer/i18n/$LL.json -t src/renderer/i18n/$LL.po + + ``` -4. Send `src/main/i18n/$LL.[json,po]` and `src/renderer/i18n/$LL.[json,po]` to the translator and wait to receive a copy with translations added. +4. Send `src/main/i18n/$LL.po` and `src/renderer/i18n/$LL.po` to the translator and wait to receive a copy with translations added. -5. (if the translator uses PO format) Convert PO to JSON - If the translator works with PO files, we can convert them to JSON using this tool: https://github.com/i18next/i18next-gettext-converter +5. Receive the updated PO files from the translator, then convert PO to JSON using [i18next-gettext-converter](https://github.com/i18next/i18next-gettext-converter). Replace `src/main/i18n/$LL.json` and `src/renderer/i18n/$LL.json` with the updated versions: + ``` + i18next-conv -l $LL -s new_main_translations.po -t src/main/i18n/$LL.json + i18next-conv -l $LL -s new_renderer_translations.po -t src/renderer/i18n/$LL.json -6. Replace `src/main/i18n/$LL.[json,po]` and `src/renderer/i18n/$LL.json` with the updated versions received from the translator + ``` 7. Commit the changes: ``` git add src/main/i18n/$LL.json src/renderer/i18n/$LL.json git commit -m "add new translations for $LL" ``` - From 7d70242cd9cab28b53f6b597c242c4bfe0705c68 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 26 Mar 2024 12:02:17 -0700 Subject: [PATCH 10/90] translations for data download test --- .../components/DataDownloadModal/index.jsx | 36 +++++++++++++++++-- 1 file changed, 34 insertions(+), 2 deletions(-) diff --git a/workbench/src/renderer/components/DataDownloadModal/index.jsx b/workbench/src/renderer/components/DataDownloadModal/index.jsx index e55a0192ce..c7e156f438 100644 --- a/workbench/src/renderer/components/DataDownloadModal/index.jsx +++ b/workbench/src/renderer/components/DataDownloadModal/index.jsx @@ -174,6 +174,38 @@ class DataDownloadModal extends React.Component { // Don't render until registry is loaded, since it loads async if (!dataRegistry) { return
; } + const displayNames = { + 'Annual Water Yield': t('Annual Water Yield'), + 'Carbon Storage and Sequestration': t('Carbon Storage and Sequestration'), + 'Coastal Blue Carbon': t('Coastal Blue Carbon'), + 'Coastal Vulnerability': t('Coastal Vulnerability'), + 'Crop Pollination': t('Crop Pollination'), + 'Crop Production': t('Crop Production'), + 'DelineateIt': t('DelineateIt'), + 'Forest Carbon Edge Effect': t('Forest Carbon Edge Effect'), + 'Habitat Quality': t('Habitat Quality'), + 'Habitat Risk Assessment': t('Habitat Risk Assessment'), + 'Nutrient Delivery Ratio': t('Nutrient Delivery Ratio'), + 'RouteDEM': t('RouteDEM'), + 'Scenario Generator: Proximity Based': t('Scenario Generator: Proximity Based'), + 'Scenic Quality': t('Scenic Quality'), + 'Seasonal Water Yield': t('Seasonal Water Yield'), + 'Sediment Delivery Ratio': t('Sediment Delivery Ratio'), + 'Urban Stormwater Retention': t('Urban Stormwater Retention'), + 'Urban Cooling': t('Urban Cooling'), + 'Urban Flood Risk Mitigation': t('Urban Flood Risk Mitigation'), + 'Urban Nature Access': t('Urban Nature Access'), + 'Visitation: Recreation and Tourism': t('Visitation: Recreation and Tourism'), + 'Wave Energy Production': t('Wave Energy Production'), + 'Wind Energy Production': t('Wind Energy Production'), + 'Global DEM & Landmass Polygon': t('Global DEM & Landmass Polygon'), + }; + const displayNotes = { + '(recommended to run model)': t('(recommended to run model)'), + '(required to run model)': t('(required to run model)'), + '(required for Wind & Wave Energy)': t('(required for Wind & Wave Energy)'), + }; + const downloadEnabled = Boolean(selectedLinksArray.length); const DatasetCheckboxRows = []; Object.keys(modelCheckBoxState) @@ -196,11 +228,11 @@ class DataDownloadModal extends React.Component { )} /> - {modelName} + {displayNames[modelName]} - {note} + {displayNotes[note]} {filesizeStr} ); From bf38e77da6689d336418979581634179d684f99f Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 26 Mar 2024 12:06:36 -0700 Subject: [PATCH 11/90] add new messages into es translation files --- workbench/src/renderer/i18n/es.json | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/workbench/src/renderer/i18n/es.json b/workbench/src/renderer/i18n/es.json index a330691af1..18d633c3f5 100644 --- a/workbench/src/renderer/i18n/es.json +++ b/workbench/src/renderer/i18n/es.json @@ -1,4 +1,31 @@ { + "Annual Water Yield": "", + "Carbon Storage and Sequestration": "", + "Coastal Blue Carbon": "", + "Coastal Vulnerability": "", + "Crop Pollination": "", + "Crop Production": "", + "DelineateIt": "", + "Forest Carbon Edge Effect": "", + "Habitat Quality": "", + "Habitat Risk Assessment": "", + "Nutrient Delivery Ratio": "", + "RouteDEM": "", + "Scenario Generator: Proximity Based": "", + "Scenic Quality": "", + "Seasonal Water Yield": "", + "Sediment Delivery Ratio": "", + "Urban Stormwater Retention": "", + "Urban Cooling": "", + "Urban Flood Risk Mitigation": "", + "Urban Nature Access": "", + "Visitation: Recreation and Tourism": "", + "Wave Energy Production": "", + "Wind Energy Production": "", + "Global DEM & Landmass Polygon": "", + "(recommended to run model)": "", + "(required to run model)": "", + "(required for Wind & Wave Energy)": "", "Please choose a different folder. This application does not have permission to write to folder:": "", "Download InVEST sample data": "Descargar datos de muestra de InVEST", "Cancel": "Cancelar", From 305de2c01b0a3e1f9f8f7ff79302d54c5ebc939e Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 26 Mar 2024 12:07:09 -0700 Subject: [PATCH 12/90] add new messages into zh translation files --- workbench/src/renderer/i18n/zh.json | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/workbench/src/renderer/i18n/zh.json b/workbench/src/renderer/i18n/zh.json index aa2c219167..a6ede53a83 100644 --- a/workbench/src/renderer/i18n/zh.json +++ b/workbench/src/renderer/i18n/zh.json @@ -1,4 +1,31 @@ { + "Annual Water Yield": "", + "Carbon Storage and Sequestration": "", + "Coastal Blue Carbon": "", + "Coastal Vulnerability": "", + "Crop Pollination": "", + "Crop Production": "", + "DelineateIt": "", + "Forest Carbon Edge Effect": "", + "Habitat Quality": "", + "Habitat Risk Assessment": "", + "Nutrient Delivery Ratio": "", + "RouteDEM": "", + "Scenario Generator: Proximity Based": "", + "Scenic Quality": "", + "Seasonal Water Yield": "", + "Sediment Delivery Ratio": "", + "Urban Stormwater Retention": "", + "Urban Cooling": "", + "Urban Flood Risk Mitigation": "", + "Urban Nature Access": "", + "Visitation: Recreation and Tourism": "", + "Wave Energy Production": "", + "Wind Energy Production": "", + "Global DEM & Landmass Polygon": "", + "(recommended to run model)": "", + "(required to run model)": "", + "(required for Wind & Wave Energy)": "", "Please choose a different folder. This application does not have permission to write to folder:": "", "Download InVEST sample data": "下载InVEST样例数据", "Cancel": "取消", From e53094dd1463666651b13f27808483c9df37315d Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 29 Apr 2024 10:18:48 -0700 Subject: [PATCH 13/90] update ES message catalog with new translations --- .../locales/es/LC_MESSAGES/messages.po | 4103 +++++++++-------- 1 file changed, 2052 insertions(+), 2051 deletions(-) diff --git a/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po b/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po index 52f28b5cbd..6414e583cd 100644 --- a/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po +++ b/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po @@ -8,15 +8,16 @@ msgstr "" "Project-Id-Version: InVEST 3.12\n" "Report-Msgid-Bugs-To: natcap-software@lists.stanford.edu\n" "POT-Creation-Date: 2024-03-25 13:25-0700\n" -"PO-Revision-Date: 2022-11-19 17:42-0500\n" +"PO-Revision-Date: 2024-04-18 09:17-0500\n" "Last-Translator: Patricio Mena pamv59@gmail.com\n" -"Language: es\n" "Language-Team: es \n" -"Plural-Forms: nplurals=2; plural=(n != 1);\n" +"Language: es\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" "Generated-By: Babel 2.14.0\n" +"X-Generator: Poedit 3.4.2\n" #: src/natcap/invest/annual_water_yield.py:92 #: src/natcap/invest/annual_water_yield.py:186 @@ -32,21 +33,20 @@ msgstr "Identificador único para cada cuenca hidrográfica." #: src/natcap/invest/forest_carbon_edge_effect.py:115 #: src/natcap/invest/sdr/sdr.py:74 msgid "" -"All values in this raster must have corresponding entries in the " -"Biophysical Table." +"All values in this raster must have corresponding entries in the Biophysical " +"Table." msgstr "" -"Todos los valores de este ráster deben tener sus correspondientes inputs" -" en la Tabla Biofísica." +"Todos los valores de este ráster deben tener sus correspondientes inputs en la " +"Tabla Biofísica." #: src/natcap/invest/annual_water_yield.py:140 msgid "" -"Map of root restricting layer depth, the soil depth at which root " -"penetration is strongly inhibited because of physical or chemical " -"characteristics." +"Map of root restricting layer depth, the soil depth at which root penetration is " +"strongly inhibited because of physical or chemical characteristics." msgstr "" -"Mapa de la profundidad de la capa restrictiva de las raíces, la " -"profundidad del suelo a la que la penetración de las raíces está " -"fuertemente inhibida debido a las características físicas o químicas." +"Mapa de la profundidad de la capa restrictiva de las raíces, la profundidad del " +"suelo a la que la penetración de las raíces está fuertemente inhibida debido a " +"las características físicas o químicas." #: src/natcap/invest/annual_water_yield.py:144 msgid "root restricting layer depth" @@ -54,12 +54,11 @@ msgstr "profundidad de la capa que restringe las raíces" #: src/natcap/invest/annual_water_yield.py:154 msgid "" -"Map of plant available water content, the fraction of water that can be " -"stored in the soil profile that is available to plants." +"Map of plant available water content, the fraction of water that can be stored " +"in the soil profile that is available to plants." msgstr "" -"Mapa del contenido de agua disponible para las plantas, la fracción de " -"agua que puede almacenarse en el perfil del suelo y que está disponible " -"para las plantas." +"Mapa del contenido de agua disponible para las plantas, la fracción de agua que " +"puede almacenarse en el perfil del suelo y que está disponible para las plantas." #: src/natcap/invest/annual_water_yield.py:158 msgid "plant available water content" @@ -67,24 +66,21 @@ msgstr "contenido de agua disponible de la planta" #: src/natcap/invest/annual_water_yield.py:174 msgid "" -"Map of watershed boundaries, such that each watershed drains to a point " -"of interest where hydropower production will be analyzed." +"Map of watershed boundaries, such that each watershed drains to a point of " +"interest where hydropower production will be analyzed." msgstr "" -"Mapa de los límites de las cuencas hidrográficas, de forma que cada " -"cuenca drene a un punto de interés en el que se analizará la producción " -"hidroeléctrica." +"Mapa de los límites de las cuencas hidrográficas, de forma que cada cuenca drene " +"a un punto de interés en el que se analizará la producción hidroeléctrica." #: src/natcap/invest/annual_water_yield.py:178 src/natcap/invest/ndr/ndr.py:73 msgid "watersheds" msgstr "cuencas hidrográficas" #: src/natcap/invest/annual_water_yield.py:191 -msgid "" -"Map of subwatershed boundaries within each watershed in the Watersheds " -"map." +msgid "Map of subwatershed boundaries within each watershed in the Watersheds map." msgstr "" -"Mapa de los límites de las subcuencas dentro de cada cuenca hidrográfica " -"en el mapa de cuencas." +"Mapa de los límites de las subcuencas dentro de cada cuenca hidrográfica en el " +"mapa de cuencas." #: src/natcap/invest/annual_water_yield.py:194 msgid "sub-watersheds" @@ -92,22 +88,22 @@ msgstr "subcuencas" #: src/natcap/invest/annual_water_yield.py:202 msgid "" -"Code indicating whether the the LULC class is vegetated for the purpose " -"of AET. Enter 1 for all vegetated classes except wetlands, and 0 for all " -"other classes, including wetlands, urban areas, water bodies, etc." +"Code indicating whether the the LULC class is vegetated for the purpose of AET. " +"Enter 1 for all vegetated classes except wetlands, and 0 for all other classes, " +"including wetlands, urban areas, water bodies, etc." msgstr "" "Código que indica si la clase LULC tiene vegetación a efectos de la ETR. " -"Introduzca 1 para todas las clases con vegetación, excepto los humedales," -" y 0 para todas las demás clases, incluidos los humedales, las zonas " -"urbanas, las masas de agua, etc." +"Introduzca 1 para todas las clases con vegetación, excepto los humedales, y 0 " +"para todas las demás clases, incluidos los humedales, las zonas urbanas, las " +"masas de agua, etc." #: src/natcap/invest/annual_water_yield.py:212 msgid "" -"Maximum root depth for plants in this LULC class. Only used for classes " -"with a 'lulc_veg' value of 1." +"Maximum root depth for plants in this LULC class. Only used for classes with a " +"'lulc_veg' value of 1." msgstr "" -"Profundidad máxima de las raíces de las plantas de esta clase LULC. Solo " -"se utiliza para las clases con un valor 'lulc_veg' de 1." +"Profundidad máxima de las raíces de las plantas de esta clase LULC. Solo se " +"utiliza para las clases con un valor 'lulc_veg' de 1." #: src/natcap/invest/annual_water_yield.py:219 #: src/natcap/invest/urban_cooling_model.py:65 @@ -116,11 +112,11 @@ msgstr "Coeficiente de cultivo para esta clase de LULC." #: src/natcap/invest/annual_water_yield.py:222 msgid "" -"Table of biophysical parameters for each LULC class. All values in the " -"LULC raster must have corresponding entries in this table." +"Table of biophysical parameters for each LULC class. All values in the LULC " +"raster must have corresponding entries in this table." msgstr "" -"Tabla de parámetros biofísicos para cada clase LULC. Todos los valores " -"del ráster LULC deben tener los inputs correspondientes en esta tabla." +"Tabla de parámetros biofísicos para cada clase LULC. Todos los valores del " +"ráster LULC deben tener los inputs correspondientes en esta tabla." #: src/natcap/invest/annual_water_yield.py:226 #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:208 @@ -135,13 +131,12 @@ msgstr "tabla biofísica" #: src/natcap/invest/annual_water_yield.py:232 msgid "" -"The seasonality factor, representing hydrogeological characterisitics and" -" the seasonal distribution of precipitation. Values typically range from " -"1 - 30." +"The seasonality factor, representing hydrogeological characterisitics and the " +"seasonal distribution of precipitation. Values typically range from 1 - 30." msgstr "" -"El factor de estacionalidad, que representa las características " -"hidrogeológicas y la distribución estacional de las precipitaciones. Los " -"valores oscilan típicamente entre 1 y 30." +"El factor de estacionalidad, que representa las características hidrogeológicas " +"y la distribución estacional de las precipitaciones. Los valores oscilan " +"típicamente entre 1 y 30." #: src/natcap/invest/annual_water_yield.py:236 msgid "z parameter" @@ -157,11 +152,11 @@ msgstr "Uso consuntivo promedio del agua en esta clase de LULC." #: src/natcap/invest/annual_water_yield.py:254 msgid "" -"A table of water demand for each LULC class. Each LULC code in the LULC " -"raster must have a corresponding row in this table." +"A table of water demand for each LULC class. Each LULC code in the LULC raster " +"must have a corresponding row in this table." msgstr "" -"Una tabla de demanda de agua para cada clase LULC. Cada código LULC en el" -" raster LULC debe tener una fila correspondiente en esta tabla." +"Una tabla de demanda de agua para cada clase LULC. Cada código LULC en el raster " +"LULC debe tener una fila correspondiente en esta tabla." #: src/natcap/invest/annual_water_yield.py:258 msgid "water demand table" @@ -169,20 +164,19 @@ msgstr "tabla de demanda de agua" #: src/natcap/invest/annual_water_yield.py:265 msgid "" -"Unique identifier for the hydropower station. This must match the 'ws_id'" -" value for the corresponding watershed in the Watersheds vector. Each " -"watershed in the Watersheds vector must have its 'ws_id' entered in this " -"column." +"Unique identifier for the hydropower station. This must match the 'ws_id' value " +"for the corresponding watershed in the Watersheds vector. Each watershed in the " +"Watersheds vector must have its 'ws_id' entered in this column." msgstr "" -"Identificador único de la central hidroeléctrica. Debe coincidir con el " -"valor \"ws_id\" de la cuenca hidrográfica correspondiente en el vector " -"\"Watersheds\". Cada cuenca hidrográfica del vector Cuencas Hidrográficas" -" debe tener su \"ws_id\" introducido en esta columna." +"Identificador único de la central hidroeléctrica. Debe coincidir con el valor " +"\"ws_id\" de la cuenca hidrográfica correspondiente en el vector \"Watersheds\". " +"Cada cuenca hidrográfica del vector Cuencas Hidrográficas debe tener su " +"\"ws_id\" introducido en esta columna." #: src/natcap/invest/annual_water_yield.py:274 msgid "" -"Turbine efficiency, the proportion of potential energy captured and " -"converted to electricity by the turbine." +"Turbine efficiency, the proportion of potential energy captured and converted to " +"electricity by the turbine." msgstr "" "Eficiencia de la turbina, la proporción de energía potencial captada y " "convertida en electricidad por la turbina." @@ -190,16 +184,15 @@ msgstr "" #: src/natcap/invest/annual_water_yield.py:281 msgid "The proportion of inflow water volume that is used to generate energy." msgstr "" -"La proporción del volumen de agua de entrada que se utiliza para generar " -"energía." +"La proporción del volumen de agua de entrada que se utiliza para generar energía." #: src/natcap/invest/annual_water_yield.py:288 msgid "" -"The head, measured as the average annual effective height of water behind" -" each dam at the turbine intake." +"The head, measured as the average annual effective height of water behind each " +"dam at the turbine intake." msgstr "" -"La cabeza, medida como la altura media anual efectiva del agua detrás de " -"cada represa en la toma de la turbina." +"La cabeza, medida como la altura media anual efectiva del agua detrás de cada " +"represa en la toma de la turbina." # In these cases I don´t know if I should translate the column names. In # general I have used the Needs work button in all cases where there is doubt @@ -207,29 +200,28 @@ msgstr "" #: src/natcap/invest/annual_water_yield.py:296 #, fuzzy msgid "" -"The price of power produced by the station. Must be in the same currency " -"used in the 'cost' column." +"The price of power produced by the station. Must be in the same currency used in " +"the 'cost' column." msgstr "" -"El precio de la energía producida por la estación. Debe estar en la misma" -" moneda utilizada en la columna \"costo\"." +"El precio de la energía producida por la estación. Debe estar en la misma moneda " +"utilizada en la columna \"costo\"." #: src/natcap/invest/annual_water_yield.py:303 msgid "" -"Annual maintenance and operations cost of running the hydropower station." -" Must be in the same currency used in the 'kw_price' column." +"Annual maintenance and operations cost of running the hydropower station. Must " +"be in the same currency used in the 'kw_price' column." msgstr "" -"Costo anual de mantenimiento y explotación de la central hidroeléctrica. " -"Debe estar en la misma moneda utilizada en la columna \"kw_price\"." +"Costo anual de mantenimiento y explotación de la central hidroeléctrica. Debe " +"estar en la misma moneda utilizada en la columna \"kw_price\"." #: src/natcap/invest/annual_water_yield.py:311 msgid "" -"Number of years over which to value the hydropower station. This is " -"either the station's expected lifespan or the duration of the land use " -"scenario of interest." +"Number of years over which to value the hydropower station. This is either the " +"station's expected lifespan or the duration of the land use scenario of interest." msgstr "" -"Número de años a lo largo de los cuales valorar la central " -"hidroeléctrica. Se trata de la vida útil prevista de la central o de la " -"duración del escenario de uso del suelo de interés." +"Número de años a lo largo de los cuales valorar la central hidroeléctrica. Se " +"trata de la vida útil prevista de la central o de la duración del escenario de " +"uso del suelo de interés." #: src/natcap/invest/annual_water_yield.py:319 msgid "The annual discount rate, applied for each year in the time span." @@ -237,11 +229,11 @@ msgstr "La tasa de descuento anual, aplicada para cada año del período." #: src/natcap/invest/annual_water_yield.py:326 msgid "" -"A table mapping each watershed to the associated valuation parameters for" -" its hydropower station." +"A table mapping each watershed to the associated valuation parameters for its " +"hydropower station." msgstr "" -"Una tabla que relaciona cada cuenca con los parámetros de valoración " -"asociados a su central hidroeléctrica." +"Una tabla que relaciona cada cuenca con los parámetros de valoración asociados a " +"su central hidroeléctrica." #: src/natcap/invest/annual_water_yield.py:329 msgid "hydropower valuation table" @@ -249,27 +241,25 @@ msgstr "tabla de valoración hidroeléctrica" #: src/natcap/invest/carbon.py:59 msgid "" -"A map of LULC for the current scenario. All values in this raster must " -"have corresponding entries in the Carbon Pools table." +"A map of LULC for the current scenario. All values in this raster must have " +"corresponding entries in the Carbon Pools table." msgstr "" -"Un mapa de LULC para el escenario actual. Todos los valores de este " -"ráster deben tener los inputs correspondientes en la tabla de reservas de" -" carbono." +"Un mapa de LULC para el escenario actual. Todos los valores de este ráster deben " +"tener los inputs correspondientes en la tabla de reservas de carbono." #: src/natcap/invest/carbon.py:63 msgid "current LULC" -msgstr "LULC actual" +msgstr "actua LULC" #: src/natcap/invest/carbon.py:68 msgid "" -"Run sequestration analysis. This requires inputs of LULC maps for both " -"current and future scenarios. Required if REDD scenario analysis or run " -"valuation model is selected." +"Run sequestration analysis. This requires inputs of LULC maps for both current " +"and future scenarios. Required if REDD scenario analysis or run valuation model " +"is selected." msgstr "" -"Ejecutar el análisis de secuestración. Esto requiere la introducción de " -"mapas LULC para los escenarios actuales y futuros. Es necesario si se " -"selecciona el análisis del escenario REDD o la ejecución del modelo de " -"valoración." +"Ejecutar el análisis de secuestración. Esto requiere la introducción de mapas " +"LULC para los escenarios actuales y futuros. Es necesario si se selecciona el " +"análisis del escenario REDD o la ejecución del modelo de valoración." #: src/natcap/invest/carbon.py:73 msgid "calculate sequestration" @@ -278,32 +268,32 @@ msgstr "calcular la secuestración" #: src/natcap/invest/carbon.py:80 #, fuzzy msgid "" -"A map of LULC for the future scenario. If run valuation model is " -"selected, this should be the reference, or baseline, future scenario " -"against which to compare the REDD policy scenario. All values in this " -"raster must have corresponding entries in the Carbon Pools table. " -"Required if Calculate Sequestration is selected." +"A map of LULC for the future scenario. If run valuation model is selected, this " +"should be the reference, or baseline, future scenario against which to compare " +"the REDD policy scenario. All values in this raster must have corresponding " +"entries in the Carbon Pools table. Required if Calculate Sequestration is " +"selected." msgstr "" "Un mapa de LULC para el escenario futuro. Si se selecciona el modelo de " -"ejecución de valoración, este debe ser el escenario futuro de referencia," -" o línea de base, con el que se comparará el escenario de la política " -"REDD. Todos los valores de este ráster deben tener los inputs " -"correspondientes en la tabla de reservas de carbono. Es necesario si se " -"selecciona la opción de calcular secuestración." +"ejecución de valoración, este debe ser el escenario futuro de referencia, o " +"línea de base, con el que se comparará el escenario de la política REDD. Todos " +"los valores de este ráster deben tener los inputs correspondientes en la tabla " +"de reservas de carbono. Es necesario si se selecciona la opción de calcular " +"secuestración." #: src/natcap/invest/carbon.py:88 msgid "future LULC" -msgstr "LULC futuro" +msgstr "futuro LULC" #: src/natcap/invest/carbon.py:93 msgid "" -"Run REDD scenario analysis. This requires three LULC maps: one for the " -"current scenario, one for the future baseline scenario, and one for the " -"future REDD policy scenario." +"Run REDD scenario analysis. This requires three LULC maps: one for the current " +"scenario, one for the future baseline scenario, and one for the future REDD " +"policy scenario." msgstr "" -"Ejecutar el análisis del escenario REDD. Esto requiere tres mapas LULC: " -"uno para el escenario actual, otro para el escenario de referencia futuro" -" y otro para el escenario de la futura política REDD." +"Ejecutar el análisis del escenario REDD. Esto requiere tres mapas LULC: uno para " +"el escenario actual, otro para el escenario de referencia futuro y otro para el " +"escenario de la futura política REDD." #: src/natcap/invest/carbon.py:98 msgid "REDD scenario analysis" @@ -312,14 +302,13 @@ msgstr "Análisis del escenario REDD" #: src/natcap/invest/carbon.py:105 #, fuzzy msgid "" -"A map of LULC for the REDD policy scenario. All values in this raster " -"must have corresponding entries in the Carbon Pools table. Required if " -"REDD Scenario Analysis is selected." +"A map of LULC for the REDD policy scenario. All values in this raster must have " +"corresponding entries in the Carbon Pools table. Required if REDD Scenario " +"Analysis is selected." msgstr "" -"Un mapa de LULC para el escenario de la política REDD. Todos los valores " -"de este ráster deben tener los inputs correspondientes en la tabla de " -"reservas de carbono. En necesario si se selecciona el análisis del " -"escenario REDD." +"Un mapa de LULC para el escenario de la política REDD. Todos los valores de este " +"ráster deben tener los inputs correspondientes en la tabla de reservas de " +"carbono. En necesario si se selecciona el análisis del escenario REDD." #: src/natcap/invest/carbon.py:110 msgid "REDD LULC" @@ -344,8 +333,8 @@ msgstr "Densidad de carbono de la materia muerta." #: src/natcap/invest/carbon.py:134 msgid "A table that maps each LULC code to carbon pool data for that LULC type." msgstr "" -"Una tabla que mapea cada código LULC con los datos de la reserva de " -"carbono para ese tipo LULC." +"Una tabla que mapea cada código LULC con los datos de la reserva de carbono para " +"ese tipo LULC." #: src/natcap/invest/carbon.py:137 msgid "carbon pools" @@ -354,12 +343,11 @@ msgstr "reservas de carbono" #: src/natcap/invest/carbon.py:144 #, fuzzy msgid "" -"The calendar year of the current scenario depicted in the current LULC " -"map. Required if Run Valuation model is selected." +"The calendar year of the current scenario depicted in the current LULC map. " +"Required if Run Valuation model is selected." msgstr "" -"El año calendario del escenario actual representado en el mapa LULC " -"actual. Es necesario si se selecciona el modelo de ejecución de " -"valoración." +"El año calendario del escenario actual representado en el mapa LULC actual. Es " +"necesario si se selecciona el modelo de ejecución de valoración." #: src/natcap/invest/carbon.py:147 msgid "current LULC year" @@ -368,19 +356,19 @@ msgstr "año LULC actual" #: src/natcap/invest/carbon.py:154 #, fuzzy msgid "" -"The calendar year of the future scenario depicted in the future LULC map." -" Required if Run Valuation model is selected." +"The calendar year of the future scenario depicted in the future LULC map. " +"Required if Run Valuation model is selected." msgstr "" -"El año natural del escenario futuro representado en el mapa LULC futuro. " -"Es necesario si se selecciona el modelo de ejecución de valoración." +"El año natural del escenario futuro representado en el mapa LULC futuro. Es " +"necesario si se selecciona el modelo de ejecución de valoración." #: src/natcap/invest/carbon.py:162 msgid "" -"Calculate net present value for the future scenario, and the REDD " -"scenario if provided, and report it in the final HTML document." +"Calculate net present value for the future scenario, and the REDD scenario if " +"provided, and report it in the final HTML document." msgstr "" -"Calcule el valor actual neto para el escenario futuro, y el escenario " -"REDD si se proporciona, e infórmelo en el documento HTML final." +"Calcule el valor actual neto para el escenario futuro, y el escenario REDD si se " +"proporciona, e infórmelo en el documento HTML final." #: src/natcap/invest/carbon.py:166 msgid "run valuation model" @@ -390,8 +378,8 @@ msgstr "correr el modelo de valoración" #, fuzzy msgid "The present value of carbon. Required if Run Valuation model is selected." msgstr "" -"El valor actual del carbono. Se necesita si se selecciona el modelo de " -"ejecución de valoración." +"El valor actual del carbono. Se necesita si se selecciona el modelo de ejecución " +"de valoración." #: src/natcap/invest/carbon.py:175 msgid "price of carbon" @@ -400,14 +388,13 @@ msgstr "precio del carbono" #: src/natcap/invest/carbon.py:180 #, fuzzy msgid "" -"The annual market discount rate in the price of carbon, which reflects " -"society's preference for immediate benefits over future benefits. " -"Required if Run Valuation model is selected." +"The annual market discount rate in the price of carbon, which reflects society's " +"preference for immediate benefits over future benefits. Required if Run " +"Valuation model is selected." msgstr "" -"La tasa de descuento anual del mercado en el precio del carbono, que " -"refleja la preferencia de la sociedad por los beneficios inmediatos " -"frente a los futuros. Requerido si se selecciona el modelo de ejecución " -"de valoración." +"La tasa de descuento anual del mercado en el precio del carbono, que refleja la " +"preferencia de la sociedad por los beneficios inmediatos frente a los futuros. " +"Requerido si se selecciona el modelo de ejecución de valoración." #: src/natcap/invest/carbon.py:185 msgid "annual market discount rate" @@ -416,11 +403,11 @@ msgstr "tasa de descuento anual de mercado" #: src/natcap/invest/carbon.py:190 #, fuzzy msgid "" -"The relative annual increase of the price of carbon. Required if Run " -"Valuation model is selected." +"The relative annual increase of the price of carbon. Required if Run Valuation " +"model is selected." msgstr "" -"El incremento anual relativo del precio del carbono. Requerido si se " -"selecciona el modelo de ejecución de valoración." +"El incremento anual relativo del precio del carbono. Requerido si se selecciona " +"el modelo de ejecución de valoración." #: src/natcap/invest/carbon.py:193 msgid "annual price change" @@ -443,17 +430,17 @@ msgstr "Debe ser una geometría de punto o multipunto." #: src/natcap/invest/coastal_vulnerability.py:93 #, python-format msgid "" -"Proportion of the highest 10% of wind speeds in the record of interest " -"that blow in the direction of each sector." +"Proportion of the highest 10% of wind speeds in the record of interest that blow " +"in the direction of each sector." msgstr "" -"Proporción del 10% más alto de las velocidades de viento en el registro " -"de interés que soplan en la dirección de cada sector." +"Proporción del 10% más alto de las velocidades de viento en el registro de " +"interés que soplan en la dirección de cada sector." #: src/natcap/invest/coastal_vulnerability.py:100 #, python-format msgid "" -"Average of the highest 10% of wind speeds that blow in the direction of " -"each sector." +"Average of the highest 10% of wind speeds that blow in the direction of each " +"sector." msgstr "" "Promedio del 10% más alto de las velocidades de viento que soplan en la " "dirección de cada sector." @@ -461,29 +448,29 @@ msgstr "" #: src/natcap/invest/coastal_vulnerability.py:105 #, python-format msgid "" -"Proportion of the highest 10% of wave power values on record that are in " -"each sector." +"Proportion of the highest 10% of wave power values on record that are in each " +"sector." msgstr "" -"Proporción del 10% más alto de los valores de potencia de olas " -"registrados que se encuentran en cada sector." +"Proporción del 10% más alto de los valores de potencia de olas registrados que " +"se encuentran en cada sector." #: src/natcap/invest/coastal_vulnerability.py:111 #, python-format msgid "" -"Average of the highest 10% of wave power values on record in the " -"direction of each sector." +"Average of the highest 10% of wave power values on record in the direction of " +"each sector." msgstr "" -"Promedio del 10% más alto de valores de potencia de olas registrados en " -"la dirección de cada sector." +"Promedio del 10% más alto de valores de potencia de olas registrados en la " +"dirección de cada sector." #: src/natcap/invest/coastal_vulnerability.py:116 #, fuzzy, python-format msgid "" -"Average of the highest 10% of wind speeds that are centered on each main " -"sector direction X." +"Average of the highest 10% of wind speeds that are centered on each main sector " +"direction X." msgstr "" -"Promedio del 10% más alto de velocidades de viento centradas en cada " -"dirección X de sector principal." +"Promedio del 10% más alto de velocidades de viento centradas en cada dirección X " +"de sector principal." #: src/natcap/invest/coastal_vulnerability.py:145 msgid "Map of the region over which to run the model." @@ -492,8 +479,8 @@ msgstr "Mapa de la región sobre la que se ejecuta el modelo." #: src/natcap/invest/coastal_vulnerability.py:151 msgid "Interval at which to space shore points along the coastline." msgstr "" -"Intervalo en el que se espacian los puntos de la orilla a lo largo de la " -"línea de costa." +"Intervalo en el que se espacian los puntos de la orilla a lo largo de la línea " +"de costa." #: src/natcap/invest/coastal_vulnerability.py:153 msgid "model resolution" @@ -502,17 +489,16 @@ msgstr "resolución del modelo" #: src/natcap/invest/coastal_vulnerability.py:159 msgid "" "Map of all landmasses in and around the region of interest. It is not " -"recommended to clip this landmass to the AOI polygon because some " -"functions in the model require searching for landmasses around shore " -"points up to the distance defined in Maximum Fetch Distance, which likely" -" extends beyond the AOI polygon." -msgstr "" -"Mapa de todas las masas de tierra en y alrededor de la región de interés." -" No se recomienda recortar esta masa de tierra al polígono ADI porque " -"algunas funciones en el modelo requieren la búsqueda de masas de tierra " -"alrededor de los puntos de la costa hasta la distancia definida en la " -"distancia máxima de búsqueda, que probablemente se extiende más allá del " -"polígono AOI." +"recommended to clip this landmass to the AOI polygon because some functions in " +"the model require searching for landmasses around shore points up to the " +"distance defined in Maximum Fetch Distance, which likely extends beyond the AOI " +"polygon." +msgstr "" +"Mapa de todas las masas de tierra en y alrededor de la región de interés. No se " +"recomienda recortar esta masa de tierra al polígono ADI porque algunas funciones " +"en el modelo requieren la búsqueda de masas de tierra alrededor de los puntos de " +"la costa hasta la distancia definida en la distancia máxima de búsqueda, que " +"probablemente se extiende más allá del polígono AOI." #: src/natcap/invest/coastal_vulnerability.py:166 msgid "landmasses" @@ -520,18 +506,16 @@ msgstr "masas de tierra" #: src/natcap/invest/coastal_vulnerability.py:172 msgid "" -"Map of gridded wind and wave data that represent storm conditions. This " -"global dataset is provided with the InVEST sample data. There are 80 " -"required columns; each of the 5 types is repeated for each sixteenth " -"sector of the 360° compass: " -"[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For example:" -" REI_PCT0, V10PCT_90." -msgstr "" -"Mapa de datos cuadriculados de viento y oleaje que representan las " -"condiciones de las tormentas. Este conjunto de datos globales se " -"proporciona con los datos de muestra de InVEST. Hay 80 columnas " -"necesarias; cada uno de los 5 tipos se repite para cada decimosexto " -"sector de la brújula de 360°: " +"Map of gridded wind and wave data that represent storm conditions. This global " +"dataset is provided with the InVEST sample data. There are 80 required columns; " +"each of the 5 types is repeated for each sixteenth sector of the 360° compass: " +"[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For example: " +"REI_PCT0, V10PCT_90." +msgstr "" +"Mapa de datos cuadriculados de viento y oleaje que representan las condiciones " +"de las tormentas. Este conjunto de datos globales se proporciona con los datos " +"de muestra de InVEST. Hay 80 columnas necesarias; cada uno de los 5 tipos se " +"repite para cada decimosexto sector de la brújula de 360°: " "[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. Por ejemplo " "REI_PCT0, V10PCT_90." @@ -541,15 +525,14 @@ msgstr "WaveWatchIII" #: src/natcap/invest/coastal_vulnerability.py:186 msgid "" -"Maximum distance in meters to extend rays from shore points. Points with " -"rays equal to this distance accumulate ocean- driven wave exposure along " -"those rays and local-wind-driven wave exposure along the shorter rays." +"Maximum distance in meters to extend rays from shore points. Points with rays " +"equal to this distance accumulate ocean- driven wave exposure along those rays " +"and local-wind-driven wave exposure along the shorter rays." msgstr "" -"Distancia máxima en metros para extender los rayos desde los puntos de la" -" costa. Los puntos con rayos iguales a esta distancia acumulan la " -"exposición a las olas impulsadas por el océano a lo largo de esos rayos y" -" la exposición a las olas impulsadas por el viento local a lo largo de " -"los rayos más cortos." +"Distancia máxima en metros para extender los rayos desde los puntos de la costa. " +"Los puntos con rayos iguales a esta distancia acumulan la exposición a las olas " +"impulsadas por el océano a lo largo de esos rayos y la exposición a las olas " +"impulsadas por el viento local a lo largo de los rayos más cortos." #: src/natcap/invest/coastal_vulnerability.py:191 msgid "maximum fetch distance" @@ -557,14 +540,13 @@ msgstr "distancia máxima de alcance" #: src/natcap/invest/coastal_vulnerability.py:199 msgid "" -"Map of bathymetry (ocean depth). Bathymetry values should be negative, " -"and any positive values will be ignored. This should cover the area " -"extending beyond the AOI to the maximum fetch distance." +"Map of bathymetry (ocean depth). Bathymetry values should be negative, and any " +"positive values will be ignored. This should cover the area extending beyond the " +"AOI to the maximum fetch distance." msgstr "" -"Mapa de batimetría (profundidad del océano). Los valores de la batimetría" -" deben ser negativos, y cualquier valor positivo será ignorado. Debe " -"abarcar la zona que se extiende más allá del ADI hasta la distancia " -"máxima de alcance." +"Mapa de batimetría (profundidad del océano). Los valores de la batimetría deben " +"ser negativos, y cualquier valor positivo será ignorado. Debe abarcar la zona " +"que se extiende más allá del ADI hasta la distancia máxima de alcance." #: src/natcap/invest/coastal_vulnerability.py:205 msgid "Bathymetry" @@ -572,11 +554,11 @@ msgstr "Batimetría" #: src/natcap/invest/coastal_vulnerability.py:211 msgid "" -"Map of the edges of the continental shelf or other locally relevant " -"bathymetry contour." +"Map of the edges of the continental shelf or other locally relevant bathymetry " +"contour." msgstr "" -"Mapa de los bordes de la plataforma continental u otro contorno " -"batimétrico localmente relevante." +"Mapa de los bordes de la plataforma continental u otro contorno batimétrico " +"localmente relevante." #: src/natcap/invest/coastal_vulnerability.py:214 msgid "continental shelf contour" @@ -584,21 +566,21 @@ msgstr "contorno de la plataforma continental" #: src/natcap/invest/coastal_vulnerability.py:222 msgid "" -"Map of elevation above sea level on land. This should cover the area " -"extending beyond the AOI by at least the elevation averaging radius. " -"Elevation may be measured in any unit." +"Map of elevation above sea level on land. This should cover the area extending " +"beyond the AOI by at least the elevation averaging radius. Elevation may be " +"measured in any unit." msgstr "" -"Mapa de elevación sobre el nivel del mar en tierra. Debe cubrir el área " -"que se extiende más allá del ADI por lo menos el radio de promedio de " -"elevación. La elevación puede medirse en cualquier unidad." +"Mapa de elevación sobre el nivel del mar en tierra. Debe cubrir el área que se " +"extiende más allá del ADI por lo menos el radio de promedio de elevación. La " +"elevación puede medirse en cualquier unidad." #: src/natcap/invest/coastal_vulnerability.py:231 msgid "" -"A radius around each shore point within which to average the elevation " -"values in the DEM raster." +"A radius around each shore point within which to average the elevation values in " +"the DEM raster." msgstr "" -"Un radio alrededor de cada punto de la costa dentro del cual se promedian" -" los valores de elevación en el ráster MDE." +"Un radio alrededor de cada punto de la costa dentro del cual se promedian los " +"valores de elevación en el ráster MDE." #: src/natcap/invest/coastal_vulnerability.py:234 msgid "elevation averaging radius" @@ -610,22 +592,21 @@ msgstr "Nombre único para el hábitat. No se permiten espacios." #: src/natcap/invest/coastal_vulnerability.py:247 msgid "" -"Map of area(s) where the habitat is present. If raster, presence of the " -"habitat can be represented by any value and absence of the habitat can be" -" represented by 0 and nodata values." +"Map of area(s) where the habitat is present. If raster, presence of the habitat " +"can be represented by any value and absence of the habitat can be represented by " +"0 and nodata values." msgstr "" -"Mapa de la(s) zona(s) donde está presente el hábitat. Si se trata de un " -"raster, la presencia del hábitat puede representarse con cualquier valor " -"y la ausencia del hábitat puede representarse con valores 0 y nodata." +"Mapa de la(s) zona(s) donde está presente el hábitat. Si se trata de un raster, " +"la presencia del hábitat puede representarse con cualquier valor y la ausencia " +"del hábitat puede representarse con valores 0 y nodata." #: src/natcap/invest/coastal_vulnerability.py:254 -#, fuzzy msgid "" -"Relative amount of coastline protection this habitat provides, from 1 " -"(very high protection) to 5 (very low protection." +"Relative amount of coastline protection this habitat provides, from 1 (very high " +"protection) to 5 (very low protection." msgstr "" -"Cantidad relativa de protección de la línea de costa que proporciona este" -" hábitat." +"Cantidad relativa de protección de la línea de costa que proporciona este " +"hábitat, de 1 (protección muy alta) a 5 (protección muy baja)." #: src/natcap/invest/coastal_vulnerability.py:263 msgid "" @@ -703,13 +684,12 @@ msgstr "5: exposición muy alta" #: src/natcap/invest/coastal_vulnerability.py:303 msgid "" -"Exposure rank to assign to any shore points that are not near to any " -"segment in the geomorphology vector. Required if a Geomorphology vector " -"is provided." +"Exposure rank to assign to any shore points that are not near to any segment in " +"the geomorphology vector. Required if a Geomorphology vector is provided." msgstr "" -"Rango de exposición para asignar a cualquier punto de la costa que no " -"esté cerca de ningún segmento en el vector geomorfológico. Es necesario " -"si se proporciona un vector geomorfológico." +"Rango de exposición para asignar a cualquier punto de la costa que no esté cerca " +"de ningún segmento en el vector geomorfológico. Es necesario si se proporciona " +"un vector geomorfológico." #: src/natcap/invest/coastal_vulnerability.py:307 msgid "geomorphology fill value" @@ -728,9 +708,9 @@ msgid "" "The radius around each shore point within which to compute the average " "population density. Required if a Human Population map is provided." msgstr "" -"El radio alrededor de cada punto de la costa dentro del cual se calcula " -"la densidad media de población. Es necesario si se proporciona un mapa de" -" población humana." +"El radio alrededor de cada punto de la costa dentro del cual se calcula la " +"densidad media de población. Es necesario si se proporciona un mapa de población " +"humana." #: src/natcap/invest/coastal_vulnerability.py:327 msgid "population search radius" @@ -738,20 +718,20 @@ msgstr "radio de búsqueda de la población" #: src/natcap/invest/coastal_vulnerability.py:333 msgid "" -"Sea level rise rate or amount. This field name must be chosen as the Sea " -"Level Rise Field." +"Sea level rise rate or amount. This field name must be chosen as the Sea Level " +"Rise Field." msgstr "" -"Tasa o cantidad de aumento del nivel del mar. Este nombre de campo debe " -"elegirse como campo de aumento del nivel del mar." +"Tasa o cantidad de aumento del nivel del mar. Este nombre de campo debe elegirse " +"como campo de aumento del nivel del mar." #: src/natcap/invest/coastal_vulnerability.py:342 msgid "" -"Map of sea level rise rates or amounts. May be any sea level rise metric " -"of interest, such as rate, or net rise/fall." +"Map of sea level rise rates or amounts. May be any sea level rise metric of " +"interest, such as rate, or net rise/fall." msgstr "" -"Mapa de las tasas o cantidades de aumento del nivel del mar. Puede ser " -"cualquier métrica de aumento del nivel del mar de interés, como la tasa o" -" el aumento/descenso neto." +"Mapa de las tasas o cantidades de aumento del nivel del mar. Puede ser cualquier " +"métrica de aumento del nivel del mar de interés, como la tasa o el aumento/" +"descenso neto." #: src/natcap/invest/coastal_vulnerability.py:345 msgid "sea level rise" @@ -759,13 +739,12 @@ msgstr "aumento del nivel del mar" #: src/natcap/invest/coastal_vulnerability.py:351 msgid "" -"Name of the field in the sea level rise vector which contains the sea " -"level rise metric of interest. Required if a Sea Level Rise vector is " -"provided." +"Name of the field in the sea level rise vector which contains the sea level rise " +"metric of interest. Required if a Sea Level Rise vector is provided." msgstr "" -"Nombre del campo del vector de aumento del nivel del mar que contiene la " -"métrica de aumento del nivel del mar de interés. Es obligatorio si se " -"proporciona un vector de aumento del nivel del mar." +"Nombre del campo del vector de aumento del nivel del mar que contiene la métrica " +"de aumento del nivel del mar de interés. Es obligatorio si se proporciona un " +"vector de aumento del nivel del mar." #: src/natcap/invest/coastal_vulnerability.py:355 msgid "sea level rise field" @@ -773,12 +752,11 @@ msgstr "campo de aumento del nivel del mar" #: src/natcap/invest/crop_production_percentile.py:135 msgid "" -"A table that maps each LULC code from the LULC map to one of the 175 " -"canonical crop names representing the crop grown in that LULC class." +"A table that maps each LULC code from the LULC map to one of the 175 canonical " +"crop names representing the crop grown in that LULC class." msgstr "" -"Una tabla que asigna cada código LULC del mapa LULC a uno de los 175 " -"nombres de cultivos canónicos que representan el cultivo realizado en esa" -" clase LULC." +"Una tabla que asigna cada código LULC del mapa LULC a uno de los 175 nombres de " +"cultivos canónicos que representan el cultivo realizado en esa clase LULC." #: src/natcap/invest/crop_production_percentile.py:139 msgid "LULC to Crop Table" @@ -787,8 +765,8 @@ msgstr "Tabla de LULC a cultivos" #: src/natcap/invest/crop_production_percentile.py:151 msgid "Table mapping each climate bin to yield percentiles for each crop." msgstr "" -"Tabla que relaciona cada casilla climática con los percentiles de " -"rendimiento de cada cultivo." +"Tabla que relaciona cada casilla climática con los percentiles de rendimiento de " +"cada cultivo." #: src/natcap/invest/crop_production_percentile.py:182 #: src/natcap/invest/crop_production_regression.py:169 @@ -846,12 +824,11 @@ msgstr "trigo" #: src/natcap/invest/crop_production_regression.py:96 msgid "" -"A table that maps each LULC code from the LULC map to one of the 10 " -"canonical crop names representing the crop grown in that LULC class." +"A table that maps each LULC code from the LULC map to one of the 10 canonical " +"crop names representing the crop grown in that LULC class." msgstr "" -"Una tabla que asigna cada código LULC del mapa LULC a uno de los 10 " -"nombres de cultivos canónicos que representan el cultivo realizado en esa" -" clase LULC." +"Una tabla que asigna cada código LULC del mapa LULC a uno de los 10 nombres de " +"cultivos canónicos que representan el cultivo realizado en esa clase LULC." #: src/natcap/invest/crop_production_regression.py:100 msgid "LULC to crop table" @@ -874,29 +851,28 @@ msgstr "tabla de tasas de fertilización" #: src/natcap/invest/crop_production_regression.py:191 msgid "The Crop Production datasets provided with the model." msgstr "" -"Los conjuntos de datos de producción de cultivos que se proporcionan con " -"el modelo." +"Los conjuntos de datos de producción de cultivos que se proporcionan con el " +"modelo." #: src/natcap/invest/crop_production_regression.py:192 msgid "model data" msgstr "datos del modelo" -# In this case I am not sure about translatingf the selected item. +# In this case I am not sure about translating the selected item. #: src/natcap/invest/forest_carbon_edge_effect.py:51 #, fuzzy msgid "" -"Number of closest regression models that are used when calculating the " -"total biomass. Each local model is linearly weighted by distance such " -"that the pixel's biomass is a function of each of these points with the " -"closest point having the largest effect. Must be an integer greater than " -"0. Required if Compute Forest Edge Effects is selected." +"Number of closest regression models that are used when calculating the total " +"biomass. Each local model is linearly weighted by distance such that the pixel's " +"biomass is a function of each of these points with the closest point having the " +"largest effect. Must be an integer greater than 0. Required if Compute Forest " +"Edge Effects is selected." msgstr "" -"Número de modelos de regresión más cercanos que se utilizan al calcular " -"la biomasa total. Cada modelo local está ponderado linealmente por la " -"distancia, de manera que la biomasa del píxel es una función de cada uno " -"de estos puntos, teniendo el punto más cercano el mayor efecto. Debe ser " -"un número entero mayor que 0. Se necesita si se selecciona el cálculo de " -"efectos de borde de bosque." +"Número de modelos de regresión más cercanos que se utilizan al calcular la " +"biomasa total. Cada modelo local está ponderado linealmente por la distancia, de " +"manera que la biomasa del píxel es una función de cada uno de estos puntos, " +"teniendo el punto más cercano el mayor efecto. Debe ser un número entero mayor " +"que 0. Se necesita si se selecciona el cálculo de efectos de borde de bosque." #: src/natcap/invest/forest_carbon_edge_effect.py:59 msgid "number of points to average" @@ -904,49 +880,45 @@ msgstr "número de puntos a promediar" #: src/natcap/invest/forest_carbon_edge_effect.py:73 msgid "" -"Enter 1 if the LULC class is tropical forest, 0 if it is not tropical " -"forest." +"Enter 1 if the LULC class is tropical forest, 0 if it is not tropical forest." msgstr "" -"Introduzca 1 si la clase LULC es bosque tropical, 0 si no es bosque " -"tropical." +"Introduzca 1 si la clase LULC es bosque tropical, 0 si no es bosque tropical." #: src/natcap/invest/forest_carbon_edge_effect.py:79 msgid "Carbon density value for the aboveground carbon pool." msgstr "" -"Valor de la densidad del carbono para la reserva de carbono sobre el " -"suelo." +"Valor de la densidad del carbono para la reserva de carbono sobre el suelo." #: src/natcap/invest/forest_carbon_edge_effect.py:87 msgid "" -"Carbon density value for the belowground carbon pool. Required if " -"calculating all pools." +"Carbon density value for the belowground carbon pool. Required if calculating " +"all pools." msgstr "" -"Valor de la densidad del carbono para la reserva de carbono subterránea. " -"Es necesario si se calculan todas las reservas." +"Valor de la densidad del carbono para la reserva de carbono subterránea. Es " +"necesario si se calculan todas las reservas." #: src/natcap/invest/forest_carbon_edge_effect.py:95 msgid "" -"Carbon density value for the soil carbon pool. Required if calculating " -"all pools." +"Carbon density value for the soil carbon pool. Required if calculating all pools." msgstr "" -"Valor de la densidad del carbono para la reserva de carbono del suelo. Es" -" necesario si se calculan todas las reservas." +"Valor de la densidad del carbono para la reserva de carbono del suelo. Es " +"necesario si se calculan todas las reservas." #: src/natcap/invest/forest_carbon_edge_effect.py:103 msgid "" -"Carbon density value for the dead matter carbon pool. Required if " -"calculating all pools." +"Carbon density value for the dead matter carbon pool. Required if calculating " +"all pools." msgstr "" -"Valor de la densidad del carbono para la reserva de carbono de la materia" -" muerta. Es necesario si se calculan todas las reservas." +"Valor de la densidad del carbono para la reserva de carbono de la materia " +"muerta. Es necesario si se calculan todas las reservas." #: src/natcap/invest/forest_carbon_edge_effect.py:108 msgid "" -"A table mapping each LULC code from the LULC map to biophysical data for " -"that LULC class." +"A table mapping each LULC code from the LULC map to biophysical data for that " +"LULC class." msgstr "" -"Una tabla que relaciona cada código LULC del mapa LULC con los datos " -"biofísicos de esa clase LULC." +"Una tabla que relaciona cada código LULC del mapa LULC con los datos biofísicos " +"de esa clase LULC." #: src/natcap/invest/forest_carbon_edge_effect.py:124 msgid "all" @@ -954,11 +926,11 @@ msgstr "todos" #: src/natcap/invest/forest_carbon_edge_effect.py:125 msgid "" -"Use all pools (aboveground, belowground, soil, and dead matter) in the " -"carbon pool calculation." +"Use all pools (aboveground, belowground, soil, and dead matter) in the carbon " +"pool calculation." msgstr "" -"Utilice todas las reservas (sobre el suelo, bajo el suelo, suelo y " -"materia muerta) en el cálculo del depósito de carbono." +"Utilice todas las reservas (sobre el suelo, bajo el suelo, suelo y materia " +"muerta) en el cálculo del depósito de carbono." #: src/natcap/invest/forest_carbon_edge_effect.py:129 msgid "aboveground only" @@ -967,8 +939,7 @@ msgstr "solo en la superficie" #: src/natcap/invest/forest_carbon_edge_effect.py:130 msgid "Only use the aboveground pool in the carbon pool calculation." msgstr "" -"Solo utilice la reserva sobre el suelo en el cálculo de la reserva de " -"carbono." +"Solo utilice la reserva sobre el suelo en el cálculo de la reserva de carbono." #: src/natcap/invest/forest_carbon_edge_effect.py:134 msgid "Which carbon pools to consider." @@ -981,8 +952,8 @@ msgstr "reservas de carbono a calcular" #: src/natcap/invest/forest_carbon_edge_effect.py:139 msgid "Account for forest edge effects on aboveground carbon." msgstr "" -"Tanga en cuenta los efectos de los bordes del bosque sobre el carbono " -"sobre el suelo." +"Tanga en cuenta los efectos de los bordes del bosque sobre el carbono sobre el " +"suelo." #: src/natcap/invest/forest_carbon_edge_effect.py:140 msgid "compute forest edge effects" @@ -1014,24 +985,23 @@ msgstr "parámetro θ₂ para la ecuación de regresión." #: src/natcap/invest/forest_carbon_edge_effect.py:165 msgid "" -"θ₃ parameter for the regression equation. Used only for the asymptotic " -"model." +"θ₃ parameter for the regression equation. Used only for the asymptotic model." msgstr "" -"parámetro θ₃ para la ecuación de regresión. Se utiliza solamente para el " -"modelo asintótico." +"parámetro θ₃ para la ecuación de regresión. Se utiliza solamente para el modelo " +"asintótico." # Idem #: src/natcap/invest/forest_carbon_edge_effect.py:171 #, fuzzy msgid "" -"Map storing the optimal regression model for each tropical subregion and " -"the corresponding theta parameters for that regression equation. Default " -"data is provided. Required if Compute Forest Edge Effects is selected." +"Map storing the optimal regression model for each tropical subregion and the " +"corresponding theta parameters for that regression equation. Default data is " +"provided. Required if Compute Forest Edge Effects is selected." msgstr "" -"Mapa que almacena el modelo de regresión óptimo para cada subregión " -"tropical y los parámetros theta correspondientes para esa ecuación de " -"regresión. Se proporcionan datos por defecto. Es necesario si se " -"selecciona la opción de calcular los efectos de los bordes del bosque." +"Mapa que almacena el modelo de regresión óptimo para cada subregión tropical y " +"los parámetros theta correspondientes para esa ecuación de regresión. Se " +"proporcionan datos por defecto. Es necesario si se selecciona la opción de " +"calcular los efectos de los bordes del bosque." #: src/natcap/invest/forest_carbon_edge_effect.py:176 msgid "global regression models" @@ -1040,12 +1010,12 @@ msgstr "modelos de regresión global" #: src/natcap/invest/forest_carbon_edge_effect.py:181 #, fuzzy msgid "" -"Proportion of forest edge biomass that is elemental carbon. Required if " -"Compute Forest Edge Effects is selected." +"Proportion of forest edge biomass that is elemental carbon. Required if Compute " +"Forest Edge Effects is selected." msgstr "" -"Proporción de la biomasa del borde del bosque que es carbono elemental. " -"Es necesaria si se selecciona la opción de calcular los efectos del " -"borde del bosque." +"Proporción de la biomasa del borde del bosque que es carbono elemental. Es " +"necesaria si se selecciona la opción de calcular los efectos del borde del " +"bosque." #: src/natcap/invest/forest_carbon_edge_effect.py:184 msgid "forest edge biomass to carbon conversion factor" @@ -1057,17 +1027,17 @@ msgid "" "Threats {threats} does not match any column in the sensitivity table. " "Sensitivity columns: {column_names}" msgstr "" -"Amenazas {threats} no coincide con ninguna columna de la tabla de " -"sensibilidad. Columnas de sensibilidad: {column_names}" +"Amenazas {threats} no coincide con ninguna columna de la tabla de sensibilidad. " +"Columnas de sensibilidad: {column_names}" #: src/natcap/invest/habitat_quality.py:24 #, fuzzy msgid "" -"A threat raster for threats: {threat_list} was not found or it could not " -"be opened by GDAL." +"A threat raster for threats: {threat_list} was not found or it could not be " +"opened by GDAL." msgstr "" -"No se halló un ráster de amenazas para las amenazas: {threat_list} o no " -"pudo ser abierta por GDAL." +"No se halló un ráster de amenazas para las amenazas: {threat_list} o no pudo ser " +"abierta por GDAL." #: src/natcap/invest/habitat_quality.py:27 msgid "Threat paths must be unique. Duplicates: " @@ -1075,11 +1045,11 @@ msgstr "Las rutas de las amenazas deben ser únicas. Duplicados: " #: src/natcap/invest/habitat_quality.py:46 msgid "" -"Map of LULC at present. All values in this raster must have corresponding" -" entries in the Sensitivity table." +"Map of LULC at present. All values in this raster must have corresponding " +"entries in the Sensitivity table." msgstr "" -"Mapa de LULC en la actualidad. Todos los valores de este raster deben " -"tener los inputs correspondientes en la tabla de sensibilidad." +"Mapa de LULC en la actualidad. Todos los valores de este raster deben tener los " +"inputs correspondientes en la tabla de sensibilidad." #: src/natcap/invest/habitat_quality.py:49 msgid "current land cover" @@ -1088,13 +1058,12 @@ msgstr "cobertura del suelo actual" #: src/natcap/invest/habitat_quality.py:55 msgid "" "Map of LULC in a future scenario. All values in this raster must have " -"corresponding entries in the Sensitivity Table. Must use the same " -"classification scheme and codes as in the Current LULC map." +"corresponding entries in the Sensitivity Table. Must use the same classification " +"scheme and codes as in the Current LULC map." msgstr "" -"Mapa de LULC en un escenario futuro. Todos los valores de este ráster " -"deben tener los inputs correspondientes en la Tabla de Sensibilidad. Debe" -" utilizar el mismo esquema de clasificación y códigos que en el mapa LULC" -" actual." +"Mapa de LULC en un escenario futuro. Todos los valores de este ráster deben " +"tener los inputs correspondientes en la Tabla de Sensibilidad. Debe utilizar el " +"mismo esquema de clasificación y códigos que en el mapa LULC actual." #: src/natcap/invest/habitat_quality.py:60 msgid "future land cover" @@ -1102,16 +1071,15 @@ msgstr "cobertura futura del suelo" #: src/natcap/invest/habitat_quality.py:66 msgid "" -"Map of LULC in a baseline scenario, when intensive landscape management " -"was relatively rare. All values in this raster must have corresponding " -"entries in the Sensitivity table. Must use the same classification scheme" -" and codes as in the Current LULC map." +"Map of LULC in a baseline scenario, when intensive landscape management was " +"relatively rare. All values in this raster must have corresponding entries in " +"the Sensitivity table. Must use the same classification scheme and codes as in " +"the Current LULC map." msgstr "" -"Mapa de LULC en un escenario de referencia, cuando la gestión intensiva " -"del paisaje era relativamente rara. Todos los valores de este ráster " -"deben tener los inputs correspondientes en la tabla de sensibilidad. Debe" -" utilizar el mismo esquema de clasificación y códigos del mapa LULC " -"actual." +"Mapa de LULC en un escenario de referencia, cuando la gestión intensiva del " +"paisaje era relativamente rara. Todos los valores de este ráster deben tener los " +"inputs correspondientes en la tabla de sensibilidad. Debe utilizar el mismo " +"esquema de clasificación y códigos del mapa LULC actual." #: src/natcap/invest/habitat_quality.py:72 msgid "baseline land cover" @@ -1119,35 +1087,33 @@ msgstr "cobertura terrestre de línea de base" #: src/natcap/invest/habitat_quality.py:80 msgid "" -"Name of the threat. Each threat name must have a corresponding column in " -"the Sensitivity table." +"Name of the threat. Each threat name must have a corresponding column in the " +"Sensitivity table." msgstr "" "Nombre de la amenaza. Cada nombre de amenaza debe tener una columna " "correspondiente en la tabla de sensibilidad." #: src/natcap/invest/habitat_quality.py:86 msgid "" -"The maximum distance over which each threat affects habitat quality. The " -"impact of each degradation source will decline to zero at this maximum " -"distance. This value must be greater than or equal to the pixel size of " -"your LULC raster(s)." +"The maximum distance over which each threat affects habitat quality. The impact " +"of each degradation source will decline to zero at this maximum distance. This " +"value must be greater than or equal to the pixel size of your LULC raster(s)." msgstr "" -"La distancia máxima a la que cada amenaza afecta a la calidad del " -"hábitat. El impacto de cada fuente de degradación se reducirá a cero en " -"esta distancia máxima. Este valor debe ser mayor o igual que el tamaño " -"del píxel de lo(s) ráster(s) LULC." +"La distancia máxima a la que cada amenaza afecta a la calidad del hábitat. El " +"impacto de cada fuente de degradación se reducirá a cero en esta distancia " +"máxima. Este valor debe ser mayor o igual que el tamaño del píxel de lo(s) " +"ráster(s) LULC." #: src/natcap/invest/habitat_quality.py:95 msgid "The impact of each threat on habitat quality, relative to other threats." msgstr "" -"El impacto de cada amenaza en la calidad del hábitat, en relación con " -"otras amenazas." +"El impacto de cada amenaza en la calidad del hábitat, en relación con otras " +"amenazas." #: src/natcap/invest/habitat_quality.py:103 msgid "Effects of the threat decay linearly with distance from the threat." msgstr "" -"Los efectos de la amenaza decaen linealmente con la distancia a la " -"amenaza." +"Los efectos de la amenaza decaen linealmente con la distancia a la amenaza." #: src/natcap/invest/habitat_quality.py:107 msgid "Effects of the threat decay exponentially with distance from the threat." @@ -1158,45 +1124,41 @@ msgid "The type of decay over space for each threat." msgstr "El tipo de decaimiento a lo largo del espacio para cada amenaza." #: src/natcap/invest/habitat_quality.py:116 -#, fuzzy msgid "" -"Path to a raster of the threat's distribution in the current scenario. " -"Each pixel value in this raster is the relative intensity of the threat " -"at that location, with values between 0 and 1." +"Path to a raster of the threat's distribution in the current scenario. Each " +"pixel value in this raster is the relative intensity of the threat at that " +"location, with values between 0 and 1." msgstr "" -"Mapa de la distribución de la amenaza en el escenario actual. El valor de" -" cada píxel es la intensidad relativa de la amenaza en ese lugar. " +"Mapa de la distribución de la amenaza en el escenario actual. El valor de cada " +"píxel es la intensidad relativa de la amenaza en ese lugar." #: src/natcap/invest/habitat_quality.py:127 -#, fuzzy msgid "" -"Path to a raster of the threat's distribution in a future scenario. Each " -"pixel value in this raster is the relative intensity of the threat at " -"that location, with values between 0 and 1." +"Path to a raster of the threat's distribution in a future scenario. Each pixel " +"value in this raster is the relative intensity of the threat at that location, " +"with values between 0 and 1." msgstr "" -"Mapa de la distribución de la amenaza en el escenario actual. El valor de" -" cada píxel es la intensidad relativa de la amenaza en ese lugar. " +"Mapa de la distribución de la amenaza en el escenario actual. El valor de cada " +"píxel es la intensidad relativa de la amenaza en ese lugar." #: src/natcap/invest/habitat_quality.py:138 #, fuzzy msgid "" -"Path to a raster of the threat's distribution in the baseline scenario. " -"Each pixel value in this raster is the relative intensity of the threat " -"at that location, with values between 0 and 1. Required if Baseline LULC " -"is provided." +"Path to a raster of the threat's distribution in the baseline scenario. Each " +"pixel value in this raster is the relative intensity of the threat at that " +"location, with values between 0 and 1. Required if Baseline LULC is provided." msgstr "" -"Mapa de la distribución de la amenaza en el escenario base. El valor de " -"cada píxel es la intensidad relativa de la amenaza en ese lugar. " -"Necesario si se proporciona el LULC de referencia." +"Mapa de la distribución de la amenaza en el escenario base. El valor de cada " +"píxel es la intensidad relativa de la amenaza en ese lugar. Necesario si se " +"proporciona el LULC de referencia." #: src/natcap/invest/habitat_quality.py:146 msgid "" -"Table mapping each threat of interest to its properties and distribution " -"maps. Paths are relative to the threats table path." +"Table mapping each threat of interest to its properties and distribution maps. " +"Paths are relative to the threats table path." msgstr "" -"Tabla que relaciona cada amenaza de interés con sus propiedades y mapas " -"de distribución. Las rutas son relativas a la ruta de la tabla de " -"amenazas." +"Tabla que relaciona cada amenaza de interés con sus propiedades y mapas de " +"distribución. Las rutas son relativas a la ruta de la tabla de amenazas." #: src/natcap/invest/habitat_quality.py:150 msgid "threats table" @@ -1204,22 +1166,21 @@ msgstr "tabla de amenazas" #: src/natcap/invest/habitat_quality.py:158 msgid "" -"The region's relative accessibility to threats, where 0 represents " -"completely inaccessible and 1 represents completely accessible." +"The region's relative accessibility to threats, where 0 represents completely " +"inaccessible and 1 represents completely accessible." msgstr "" -"La accesibilidad relativa de la región a las amenazas, en la que 0 " -"representa que es completamente inaccesible y 1 que es completamente " -"accesible." +"La accesibilidad relativa de la región a las amenazas, en la que 0 representa " +"que es completamente inaccesible y 1 que es completamente accesible." #: src/natcap/invest/habitat_quality.py:166 msgid "" -"Map of the relative protection that legal, institutional, social, and " -"physical barriers provide against threats. Any cells not covered by a " -"polygon will be set to 1." +"Map of the relative protection that legal, institutional, social, and physical " +"barriers provide against threats. Any cells not covered by a polygon will be set " +"to 1." msgstr "" "Mapa de la protección relativa que ofrecen las barreras legales, " -"institucionales, sociales y físicas contra las amenazas. Las celdas que " -"no estén cubiertas por un polígono se establecerán en 1." +"institucionales, sociales y físicas contra las amenazas. Las celdas que no estén " +"cubiertas por un polígono se establecerán en 1." #: src/natcap/invest/habitat_quality.py:170 msgid "accessibility to threats" @@ -1227,8 +1188,8 @@ msgstr "accesibilidad a las amenazas" #: src/natcap/invest/habitat_quality.py:183 msgid "" -"Suitability of this LULC class as habitat, where 0 is not suitable and 1 " -"is completely suitable." +"Suitability of this LULC class as habitat, where 0 is not suitable and 1 is " +"completely suitable." msgstr "" "Aptitud de esta clase de LULC como hábitat, donde 0 es no apto y 1 es " "completamente apto." @@ -1236,24 +1197,23 @@ msgstr "" #: src/natcap/invest/habitat_quality.py:189 #, fuzzy msgid "" -"The relative sensitivity of each LULC class to each type of threat, where" -" 1 represents high sensitivity and 0 represents that it is unaffected. " -"There must be one threat column for each threat name in the 'threats' " -"column of the Threats Table." +"The relative sensitivity of each LULC class to each type of threat, where 1 " +"represents high sensitivity and 0 represents that it is unaffected. There must " +"be one threat column for each threat name in the 'threats' column of the Threats " +"Table." msgstr "" -"La sensibilidad relativa de cada clase de LULC a cada tipo de amenaza, " -"donde 1 representa una alta sensibilidad y 0 representa que no le afecta." -" Debe haber una columna de amenazas por cada nombre de amenaza en la " -"columna \"amenazas\" de la Tabla de Amenazas." +"La sensibilidad relativa de cada clase de LULC a cada tipo de amenaza, donde 1 " +"representa una alta sensibilidad y 0 representa que no le afecta. Debe haber una " +"columna de amenazas por cada nombre de amenaza en la columna \"amenazas\" de la " +"Tabla de Amenazas." #: src/natcap/invest/habitat_quality.py:197 msgid "" -"Table mapping each LULC class to data about the species' habitat " -"preference and threat sensitivity in areas with that LULC." +"Table mapping each LULC class to data about the species' habitat preference and " +"threat sensitivity in areas with that LULC." msgstr "" -"Tabla que relaciona cada clase de LULC con los datos sobre la preferencia" -" de hábitat de la especie y la sensibilidad a las amenazas en zonas con " -"ese LULC." +"Tabla que relaciona cada clase de LULC con los datos sobre la preferencia de " +"hábitat de la especie y la sensibilidad a las amenazas en zonas con ese LULC." #: src/natcap/invest/habitat_quality.py:201 msgid "sensitivity table" @@ -1278,34 +1238,33 @@ msgstr "Una tabla que describe cada hábitat y factor de estrés." #: src/natcap/invest/hra.py:68 #, fuzzy msgid "" -"A unique name for each habitat or stressor. These names must match the " -"habitat and stressor names in the Criteria Scores Table." +"A unique name for each habitat or stressor. These names must match the habitat " +"and stressor names in the Criteria Scores Table." msgstr "" -"Un nombre único para cada hábitat o factor de estrés. Estos nombres deben" -" coincidir con los nombres de los hábitats y de los factores de estrés en" -" la tabla de calificaciones de los criterios." +"Un nombre único para cada hábitat o factor de estrés. Estos nombres deben " +"coincidir con los nombres de los hábitats y de los factores de estrés en la " +"tabla de calificaciones de los criterios." #: src/natcap/invest/hra.py:77 msgid "" -"Pixel values are 1, indicating presence of the habitat/stressor, or 0 " -"indicating absence. Any values besides 0 or 1 will be treated as 0." +"Pixel values are 1, indicating presence of the habitat/stressor, or 0 indicating " +"absence. Any values besides 0 or 1 will be treated as 0." msgstr "" -"Los valores de los píxeles son 1, que indica la presencia del " -"hábitat/estrés, o 0, que indica la ausencia. Cualquier valor que no sea 0" -" o 1 se tratará como 0." +"Los valores de los píxeles son 1, que indica la presencia del hábitat/estrés, o " +"0, que indica la ausencia. Cualquier valor que no sea 0 o 1 se tratará como 0." #: src/natcap/invest/hra.py:84 msgid "" -"Map of where the habitat or stressor exists. For rasters, a pixel value " -"of 1 indicates presence of the habitat or stressor. 0 (or any other " -"value) indicates absence of the habitat or stressor. For vectors, a " -"polygon indicates an area where the habitat or stressor is present." +"Map of where the habitat or stressor exists. For rasters, a pixel value of 1 " +"indicates presence of the habitat or stressor. 0 (or any other value) indicates " +"absence of the habitat or stressor. For vectors, a polygon indicates an area " +"where the habitat or stressor is present." msgstr "" "Mapa de dónde existe el hábitat o el factor de estrés. En el caso de los " -"rásters, un valor de píxel de 1 indica la presencia del hábitat o del " -"factor de estrés. 0 (o cualquier otro valor) indica la ausencia del " -"hábitat o del factor de estrés. En el caso de los vectores, un polígono " -"indica un área en la que está presente el hábitat o el factor de estrés." +"rásters, un valor de píxel de 1 indica la presencia del hábitat o del factor de " +"estrés. 0 (o cualquier otro valor) indica la ausencia del hábitat o del factor " +"de estrés. En el caso de los vectores, un polígono indica un área en la que está " +"presente el hábitat o el factor de estrés." #: src/natcap/invest/hra.py:95 msgid "habitat" @@ -1321,22 +1280,21 @@ msgstr "Si esta fila es para un hábitat o un factor de estrés." #: src/natcap/invest/hra.py:104 msgid "" -"The desired buffer distance used to expand a given stressor’s influence " -"or footprint. This should be left blank for habitats, but must be filled " -"in for stressors. Enter 0 if no buffering is desired for a given " -"stressor. The model will round down this buffer distance to the nearest " -"cell unit. e.g., a buffer distance of 600m will buffer a stressor’s " -"footprint by two grid cells if the resolution of analysis is 250m." -msgstr "" -"La distancia de amortiguamiento deseada para ampliar la influencia o la " -"huella de un factor de estrés determinado. Debe dejarse en blanco para " -"los hábitats, pero debe rellenarse para los factores de estrés. " -"Introduzca 0 si no se desea ningún amortiguamiento para un factor " -"determinado. El modelo redondeará hacia abajo esta distancia de " -"amortiguación a la unidad de celda más cercana. Por ejemplo, una " -"distancia de amortiguación de 600m amortiguará la huella de un factor de " -"estrés en dos celdas de la cuadrícula si la resolución del análisis es de" -" 250m." +"The desired buffer distance used to expand a given stressor’s influence or " +"footprint. This should be left blank for habitats, but must be filled in for " +"stressors. Enter 0 if no buffering is desired for a given stressor. The model " +"will round down this buffer distance to the nearest cell unit. e.g., a buffer " +"distance of 600m will buffer a stressor’s footprint by two grid cells if the " +"resolution of analysis is 250m." +msgstr "" +"La distancia de amortiguamiento deseada para ampliar la influencia o la huella " +"de un factor de estrés determinado. Debe dejarse en blanco para los hábitats, " +"pero debe rellenarse para los factores de estrés. Introduzca 0 si no se desea " +"ningún amortiguamiento para un factor determinado. El modelo redondeará hacia " +"abajo esta distancia de amortiguación a la unidad de celda más cercana. Por " +"ejemplo, una distancia de amortiguación de 600m amortiguará la huella de un " +"factor de estrés en dos celdas de la cuadrícula si la resolución del análisis es " +"de 250m." #: src/natcap/invest/hra.py:118 msgid "criteria scores table" @@ -1345,8 +1303,8 @@ msgstr "tabla de calificaciones de los criterios" #: src/natcap/invest/hra.py:119 msgid "A table of criteria scores for all habitats and stressors." msgstr "" -"Una tabla de calificaciones de criterios para todos los hábitats y " -"factores de estrés." +"Una tabla de calificaciones de criterios para todos los hábitats y factores de " +"estrés." #: src/natcap/invest/hra.py:124 msgid "resolution of analysis" @@ -1354,11 +1312,11 @@ msgstr "resolución del análisis" #: src/natcap/invest/hra.py:125 msgid "" -"The resolution at which to run the analysis. The model outputs will have " -"this resolution." +"The resolution at which to run the analysis. The model outputs will have this " +"resolution." msgstr "" -"La resolución con la que se ejecuta el análisis. Los resultados del " -"modelo tendrán esta resolución." +"La resolución con la que se ejecuta el análisis. Los resultados del modelo " +"tendrán esta resolución." #: src/natcap/invest/hra.py:133 msgid "maximum criteria score" @@ -1367,8 +1325,7 @@ msgstr "calificación máxima de los criterios" #: src/natcap/invest/hra.py:134 msgid "The highest possible criteria score in the scoring system." msgstr "" -"La mayor calificación posible de los criterios en el sistema de " -"calificación." +"La mayor calificación posible de los criterios en el sistema de calificación." #: src/natcap/invest/hra.py:141 msgid "risk equation" @@ -1395,8 +1352,8 @@ msgstr "ecuación de decaimiento" #: src/natcap/invest/hra.py:153 msgid "The equation to model effects of stressors in buffer areas." msgstr "" -"La ecuación para modelizar los efectos de los factores de estrés en las " -"zonas de amortiguamiento." +"La ecuación para modelizar los efectos de los factores de estrés en las zonas de " +"amortiguamiento." #: src/natcap/invest/hra.py:158 msgid "None" @@ -1405,8 +1362,7 @@ msgstr "Ninguno" #: src/natcap/invest/hra.py:159 msgid "No decay. Stressor has full effect in the buffer area." msgstr "" -"No hay decaimiento. El factor tiene pleno efecto en la zona de " -"amortiguación." +"No hay decaimiento. El factor tiene pleno efecto en la zona de amortiguación." #: src/natcap/invest/hra.py:163 msgid "Linear" @@ -1414,11 +1370,11 @@ msgstr "Lineal" #: src/natcap/invest/hra.py:164 msgid "" -"Stressor effects in the buffer area decay linearly with distance from the" -" stressor." +"Stressor effects in the buffer area decay linearly with distance from the " +"stressor." msgstr "" -"Los efectos del factor de estres en la zona de amortiguación decaen " -"linealmente con la distancia al factor." +"Los efectos del factor de estres en la zona de amortiguación decaen linealmente " +"con la distancia al factor." #: src/natcap/invest/hra.py:168 msgid "Exponential" @@ -1426,27 +1382,27 @@ msgstr "Exponencial" #: src/natcap/invest/hra.py:169 msgid "" -"Stressor effects in the buffer area decay exponentially with distance " -"from the stressor." +"Stressor effects in the buffer area decay exponentially with distance from the " +"stressor." msgstr "" -"Los efectos del factor en la zona de amortiguación decaen " -"exponencialmente con la distancia al factor." +"Los efectos del factor en la zona de amortiguación decaen exponencialmente con " +"la distancia al factor." #: src/natcap/invest/hra.py:182 msgid "" -"Uniquely identifies each feature. Required if the vector contains more " -"than one feature." +"Uniquely identifies each feature. Required if the vector contains more than one " +"feature." msgstr "" -"Identifica de forma exclusiva cada característica. Se necesita si el " -"vector contiene más de una característica." +"Identifica de forma exclusiva cada característica. Se necesita si el vector " +"contiene más de una característica." #: src/natcap/invest/hra.py:187 msgid "" -"A GDAL-supported vector file containing features representing one or more" -" planning regions or subregions." +"A GDAL-supported vector file containing features representing one or more " +"planning regions or subregions." msgstr "" -"Un archivo vectorial compatible con GDAL que contiene características que" -" representan una o más regiones o subregiones de planificación." +"Un archivo vectorial compatible con GDAL que contiene características que " +"representan una o más regiones o subregiones de planificación." #: src/natcap/invest/hra.py:192 msgid "Number of Overlapping Stressors" @@ -1454,13 +1410,13 @@ msgstr "Número de factores de estrés superpuestos" #: src/natcap/invest/hra.py:195 msgid "" -"The number of overlapping stressors to consider as 'maximum' when " -"reclassifying risk scores into high/medium/low. Affects the breaks " -"between risk classifications." +"The number of overlapping stressors to consider as 'maximum' when reclassifying " +"risk scores into high/medium/low. Affects the breaks between risk " +"classifications." msgstr "" -"El número de factores de estrés superpuestos a considerar como \"máximo\"" -" al reclasificar las calificaciones de riesgo en alto/medio/bajo. Afecta " -"a las rupturas entre las clasificaciones de riesgo." +"El número de factores de estrés superpuestos a considerar como \"máximo\" al " +"reclasificar las calificaciones de riesgo en alto/medio/bajo. Afecta a las " +"rupturas entre las clasificaciones de riesgo." #: src/natcap/invest/hra.py:204 msgid "Generate GeoJSONs" @@ -1568,71 +1524,65 @@ msgstr "Enfriamiento urbano" #: src/natcap/invest/model_metadata.py:162 msgid "Urban Nature Access" -msgstr "" +msgstr "Acceso urbano a la naturaleza" #: src/natcap/invest/pollination.py:37 msgid "" -"Map of LULC codes. All values in this raster must have corresponding " -"entries in the Biophysical Table." +"Map of LULC codes. All values in this raster must have corresponding entries in " +"the Biophysical Table." msgstr "" -"Mapa de códigos LULC. Todos los valores de este ráster deben tener los " -"inputs correspondientes en la Tabla Biofísica." +"Mapa de códigos LULC. Todos los valores de este ráster deben tener los inputs " +"correspondientes en la Tabla Biofísica." #: src/natcap/invest/pollination.py:47 -msgid "" -"Unique name or identifier for each pollinator species or guild of " -"interest." +msgid "Unique name or identifier for each pollinator species or guild of interest." msgstr "" -"Nombre o identificador único para cada especie o gremio de polinizadores " -"de interés." +"Nombre o identificador único para cada especie o gremio de polinizadores de " +"interés." #: src/natcap/invest/pollination.py:53 msgid "" -"Utilization of the substrate by this species, where 1 indicates the " -"nesting substrate is fully utilized and 0 indicates it is not utilized at" -" all. Replace [SUBSTRATE] with substrate names matching those in the " -"Biophysical Table, so that there is a column for each substrate." +"Utilization of the substrate by this species, where 1 indicates the nesting " +"substrate is fully utilized and 0 indicates it is not utilized at all. Replace " +"[SUBSTRATE] with substrate names matching those in the Biophysical Table, so " +"that there is a column for each substrate." msgstr "" -"Utilización del sustrato por parte de esta especie, donde 1 indica que el" -" sustrato de anidación se utiliza completamente y 0 indica que no se " -"utiliza en absoluto. Reemplace [SUSTRATO] con nombres de sustratos que " -"coincidan con los de la Tabla Biofísica, de modo que haya una columna " -"para cada sustrato." +"Utilización del sustrato por parte de esta especie, donde 1 indica que el " +"sustrato de anidación se utiliza completamente y 0 indica que no se utiliza en " +"absoluto. Reemplace [SUSTRATO] con nombres de sustratos que coincidan con los de " +"la Tabla Biofísica, de modo que haya una columna para cada sustrato." #: src/natcap/invest/pollination.py:63 msgid "" -"Pollinator activity for this species/guild in each season. 1 indicates " -"maximum activity for the species/guild, and 0 indicates no activity. " -"Replace [SEASON] with season names matching those in the biophysical " -"table, so that there is a column for each season." +"Pollinator activity for this species/guild in each season. 1 indicates maximum " +"activity for the species/guild, and 0 indicates no activity. Replace [SEASON] " +"with season names matching those in the biophysical table, so that there is a " +"column for each season." msgstr "" -"Actividad de los polinizadores para esta especie o gremio en cada " -"estación. el 1 indica la máxima actividad de la especie o gremio, y el 0 " -"indica que no hay actividad. Sustituya [ESTACIÓN] por los nombres de las " -"estaciones que coincidan con los de la tabla biofísica, de modo que haya " -"una columna para cada estación." +"Actividad de los polinizadores para esta especie o gremio en cada estación. el 1 " +"indica la máxima actividad de la especie o gremio, y el 0 indica que no hay " +"actividad. Sustituya [ESTACIÓN] por los nombres de las estaciones que coincidan " +"con los de la tabla biofísica, de modo que haya una columna para cada estación." #: src/natcap/invest/pollination.py:74 msgid "Average distance that this species or guild travels to forage on flowers." msgstr "" -"Distancia media que recorre esta especie o gremio para alimentarse de " -"flores." +"Distancia media que recorre esta especie o gremio para alimentarse de flores." #: src/natcap/invest/pollination.py:80 msgid "" -"The proportion of total pollinator abundance that consists of this " -"species/guild." +"The proportion of total pollinator abundance that consists of this species/guild." msgstr "" -"La proporción de la abundancia total de polinizadores que consiste en " -"esta especie/gremio." +"La proporción de la abundancia total de polinizadores que consiste en esta " +"especie/gremio." #: src/natcap/invest/pollination.py:85 msgid "" -"A table mapping each pollinator species or guild of interest to its " -"pollination-related parameters." +"A table mapping each pollinator species or guild of interest to its pollination-" +"related parameters." msgstr "" -"Una tabla que mapea cada especie o gremio de polinizadores de interés con" -" sus parámetros relacionados con la polinización." +"Una tabla que mapea cada especie o gremio de polinizadores de interés con sus " +"parámetros relacionados con la polinización." #: src/natcap/invest/pollination.py:88 msgid "Guild Table" @@ -1641,90 +1591,83 @@ msgstr "Tabla de gremios" #: src/natcap/invest/pollination.py:97 msgid "" "Index of availability of the given substrate in this LULC class. Replace " -"[SUBSTRATE] with substrate names matching those in the Guild Table, so " -"that there is a column for each substrate." +"[SUBSTRATE] with substrate names matching those in the Guild Table, so that " +"there is a column for each substrate." msgstr "" "Índice de disponibilidad del sustrato dado en esta clase LULC. Sustituir " -"[SUSTRATO] por los nombres de los sustratos que coincidan con los de la " -"tabla de gremios, de modo que haya una columna para cada sustrato." +"[SUSTRATO] por los nombres de los sustratos que coincidan con los de la tabla de " +"gremios, de modo que haya una columna para cada sustrato." #: src/natcap/invest/pollination.py:104 msgid "" -"Abundance of flowers during the given season in this LULC class. This is " -"the proportion of land area covered by flowers, multiplied by the " -"proportion of the season for which there is that coverage. Replace " -"[SEASON] with season names matching those in the Guild Table, so that " -"there is a column for each season." -msgstr "" -"Abundancia de flores durante la estación dada en esta clase de LULC. Se " -"trata de la proporción de superficie cubierta por flores, multiplicada " -"por la proporción de la estación para la que existe esa cobertura. " -"Sustituya [ESTACIÓN] por los nombres de las estaciones que coincidan con " -"los de la tabla de gremios, de modo que haya una columna para cada " -"estación." +"Abundance of flowers during the given season in this LULC class. This is the " +"proportion of land area covered by flowers, multiplied by the proportion of the " +"season for which there is that coverage. Replace [SEASON] with season names " +"matching those in the Guild Table, so that there is a column for each season." +msgstr "" +"Abundancia de flores durante la estación dada en esta clase de LULC. Se trata de " +"la proporción de superficie cubierta por flores, multiplicada por la proporción " +"de la estación para la que existe esa cobertura. Sustituya [ESTACIÓN] por los " +"nombres de las estaciones que coincidan con los de la tabla de gremios, de modo " +"que haya una columna para cada estación." #: src/natcap/invest/pollination.py:113 msgid "" -"A table mapping each LULC class to nesting availability and floral " -"abundance data for each substrate and season in that LULC class. All " -"values in the LULC raster must have corresponding entries in this table." +"A table mapping each LULC class to nesting availability and floral abundance " +"data for each substrate and season in that LULC class. All values in the LULC " +"raster must have corresponding entries in this table." msgstr "" -"Una tabla que relacione cada clase de LULC con los datos de " -"disponibilidad de nidos y abundancia de flores para cada sustrato y " -"estación en esa clase de LULC. Todos los valores de la trama LULC deben " -"tener sus correspondientes inputs en esta tabla." +"Una tabla que relacione cada clase de LULC con los datos de disponibilidad de " +"nidos y abundancia de flores para cada sustrato y estación en esa clase de LULC. " +"Todos los valores de la trama LULC deben tener sus correspondientes inputs en " +"esta tabla." #: src/natcap/invest/pollination.py:125 -msgid "" -"Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', " -"etc." +msgid "Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', etc." msgstr "" +"Nombre del cultivo en cada poligono, por ejemplo 'arándanos', 'almendras', etc." #: src/natcap/invest/pollination.py:130 msgid "" -"The half saturation coefficient for the crop grown in this area. This is " -"the wild pollinator abundance (i.e. the proportion of all pollinators " -"that are wild) needed to reach half of the total potential pollinator-" -"dependent yield." +"The half saturation coefficient for the crop grown in this area. This is the " +"wild pollinator abundance (i.e. the proportion of all pollinators that are wild) " +"needed to reach half of the total potential pollinator-dependent yield." msgstr "" -"El coeficiente de media saturación para el cultivo que se produce en esta" -" zona. Se trata de la abundancia de polinizadores silvestres (es decir, " -"la proporción de todos los polinizadores que son silvestres) necesaria " -"para alcanzar la mitad del rendimiento total potencial dependiente de los" -" polinizadores." +"El coeficiente de media saturación para el cultivo que se produce en esta zona. " +"Se trata de la abundancia de polinizadores silvestres (es decir, la proporción " +"de todos los polinizadores que son silvestres) necesaria para alcanzar la mitad " +"del rendimiento total potencial dependiente de los polinizadores." #: src/natcap/invest/pollination.py:138 #, fuzzy msgid "" -"The season in which the crop is pollinated. Season names must match those" -" in the Guild Table and Biophysical Table." +"The season in which the crop is pollinated. Season names must match those in the " +"Guild Table and Biophysical Table." msgstr "" -"La estación en la que se poliniza el cultivo. Los nombres de las " -"estaciones deben coincidir con los de la Tabla de gremios y la Tabla " -"biofísica." +"La estación en la que se poliniza el cultivo. Los nombres de las estaciones " +"deben coincidir con los de la Tabla de gremios y la Tabla biofísica." #: src/natcap/invest/pollination.py:144 msgid "" -"The floral resources available at this farm for the given season. Replace" -" [SEASON] with season names matching those in the Guild Table and " -"Biophysical Table, so that there is one field for each season." +"The floral resources available at this farm for the given season. Replace " +"[SEASON] with season names matching those in the Guild Table and Biophysical " +"Table, so that there is one field for each season." msgstr "" "Los recursos florales disponibles en esta granja para la temporada dada. " -"Sustituya [ESTACIÓN] por los nombres de las estaciones que coincidan con " -"los de la Tabla de Gremios y la Tabla Biofísica, de modo que haya un " -"campo para cada estación." +"Sustituya [ESTACIÓN] por los nombres de las estaciones que coincidan con los de " +"la Tabla de Gremios y la Tabla Biofísica, de modo que haya un campo para cada " +"estación." #: src/natcap/invest/pollination.py:152 msgid "" -"The nesting suitability for the given substrate at this farm. given " -"substrate. Replace [SUBSTRATE] with substrate names matching those in the" -" Guild Table and Biophysical Table, so that there is one field for each " -"substrate." +"The nesting suitability for the given substrate at this farm. given substrate. " +"Replace [SUBSTRATE] with substrate names matching those in the Guild Table and " +"Biophysical Table, so that there is one field for each substrate." msgstr "" -"La idoneidad de anidación para el sustrato dado en esta granja. sustrato " -"dado. Sustituir [SUSTRATO] por los nombres de los sustratos que coincidan" -" con los de la tabla de gremios y la tabla biofísica, de modo que haya un" -" campo para cada sustrato." +"La idoneidad de anidación para el sustrato dado en esta granja. sustrato dado. " +"Sustituir [SUSTRATO] por los nombres de los sustratos que coincidan con los de " +"la tabla de gremios y la tabla biofísica, de modo que haya un campo para cada " +"sustrato." #: src/natcap/invest/pollination.py:160 msgid "The proportion of crop dependent on pollinators." @@ -1732,19 +1675,18 @@ msgstr "La proporción de cultivos que dependen de los polinizadores." #: src/natcap/invest/pollination.py:165 msgid "" -"The proportion of pollination required on the farm that is provided by " -"managed pollinators." +"The proportion of pollination required on the farm that is provided by managed " +"pollinators." msgstr "" -"La proporción de la polinización necesaria en la finca que es " -"proporcionada por los polinizadores gestionados." +"La proporción de la polinización necesaria en la finca que es proporcionada por " +"los polinizadores gestionados." #: src/natcap/invest/pollination.py:171 msgid "" -"Map of farm sites to be analyzed, with pollination data specific to each " -"farm." +"Map of farm sites to be analyzed, with pollination data specific to each farm." msgstr "" -"Mapa de lis sitios de las fincas que se van a analizar, con los datos de" -" polinización específicos de cada finca." +"Mapa de los sitios de las fincas que se van a analizar, con los datos de " +"polinización específicos de cada finca." #: src/natcap/invest/pollination.py:174 msgid "farms map" @@ -1753,43 +1695,52 @@ msgstr "mapa de fincas" #: src/natcap/invest/pollination.py:180 msgid "A copy of the input farm polygon vector file with additional fields" msgstr "" +"Una copia del archivo vectorial de polígonos de la finca de entrada con campos " +"adicionales" #: src/natcap/invest/pollination.py:212 msgid "" "Total pollinator abundance across all species per season, clipped to the " "geometry of the farm vector’s polygons." msgstr "" +"Abundancia total de polinizadores de todas las especies por estación, recortada " +"según la geometría de los polígonos del vector granja." #: src/natcap/invest/pollination.py:218 msgid "Abundance of pollinator SPECIES in season SEASON." -msgstr "" +msgstr "Abundancia de ESPECIES polinizadoras en la estación ESTACIÓN." #: src/natcap/invest/pollination.py:222 msgid "" "Index of pollinator SPECIES that could be on a pixel given its arbitrary " -"abundance factor from the table, multiplied by the habitat suitability " -"for that species at that pixel, multiplied by the available floral " -"resources that a pollinator could fly to from that pixel." +"abundance factor from the table, multiplied by the habitat suitability for that " +"species at that pixel, multiplied by the available floral resources that a " +"pollinator could fly to from that pixel." msgstr "" +"El índice de ESPECIES de polinizadores que podrían estar en un píxel dado su " +"arbitrario factor de abundancia de la tabla, multiplicado por lo apropiado del " +"hábitat para esa especie en ese píxel, multiplicado por los recursos florares " +"disponibles a los que un polinizador podría volar desde ese píxel." #: src/natcap/invest/pollination.py:232 #, fuzzy msgid "Total pollinator abundance across all species per season." -msgstr "" -"La proporción de la abundancia total de polinizadores que consiste en " -"esta especie/gremio." +msgstr "Abundancia total de polinizadores de todas las especies por estación." #: src/natcap/invest/pollination.py:238 msgid "" -"Total pollinator yield index for pixels that overlap farms, including " -"wild and managed pollinators." +"Total pollinator yield index for pixels that overlap farms, including wild and " +"managed pollinators." msgstr "" +"El índice de producción total de un polinizador para píxeles que se traslapan " +"con las fincas, incuyendo polinizadores silvestres y manejados." #: src/natcap/invest/pollination.py:245 msgid "" -"Pollinator yield index for pixels that overlap farms, for wild " -"pollinators only." +"Pollinator yield index for pixels that overlap farms, for wild pollinators only." msgstr "" +"El índice de producción de un polinizador para píxeles que se traslapan con " +"fincas, para polinizadores silvestres solamente." #: src/natcap/invest/routedem.py:18 msgid "Must be between 1 and {maximum}" @@ -1798,8 +1749,7 @@ msgstr "Debe estar entre 1 y {maximum}" #: src/natcap/invest/routedem.py:34 msgid "Index of the raster band to use, for multi-band rasters." msgstr "" -"Índice de la banda del ráster que se va a utilizar, para los rásters " -"multibanda." +"Índice de la banda del ráster que se va a utilizar, para los rásters multibanda." #: src/natcap/invest/routedem.py:36 msgid "band index" @@ -1807,19 +1757,17 @@ msgstr "índice de bandas" #: src/natcap/invest/routedem.py:43 msgid "" -"All water on a pixel flows into the most downhill of its 8 surrounding " -"pixels" +"All water on a pixel flows into the most downhill of its 8 surrounding pixels" msgstr "" -"Toda el agua de un píxel fluye hacia el más bajo de sus 8 píxeles " -"circundantes" +"Toda el agua de un píxel fluye hacia el más bajo de sus 8 píxeles circundantes" #: src/natcap/invest/routedem.py:48 msgid "" -"Flow off a pixel is modeled fractionally so that water is split among " -"multiple downslope pixels" +"Flow off a pixel is modeled fractionally so that water is split among multiple " +"downslope pixels" msgstr "" -"El flujo de un píxel se modeliza de forma fraccionada para que el agua se" -" reparta entre varios píxeles pendiente abajo" +"El flujo de un píxel se modeliza de forma fraccionada para que el agua se " +"reparta entre varios píxeles pendiente abajo" #: src/natcap/invest/routedem.py:52 msgid "The routing algorithm to use." @@ -1840,8 +1788,7 @@ msgstr "cálcular la dirección del flujo" #: src/natcap/invest/routedem.py:64 msgid "Calculate flow accumulation from the flow direction output." msgstr "" -"Calcular la acumulación de flujo a partir de la salida de la dirección " -"del flujo." +"Calcular la acumulación de flujo a partir de la salida de la dirección del flujo." #: src/natcap/invest/routedem.py:66 msgid "calculate flow accumulation" @@ -1861,11 +1808,11 @@ msgstr "Necesario si se selecciona la opción de calcular corrientes." #: src/natcap/invest/routedem.py:85 msgid "" -"Calculate flow distance from each pixel to a stream as defined in the " -"Calculate Streams output." +"Calculate flow distance from each pixel to a stream as defined in the Calculate " +"Streams output." msgstr "" -"Calcule la distancia del flujo de cada píxel a una corriente como se " -"define en el resultado de Calcular corrientes." +"Calcule la distancia del flujo de cada píxel a una corriente como se define en " +"el resultado de Calcular corrientes." #: src/natcap/invest/routedem.py:88 msgid "calculate distance to stream" @@ -1880,29 +1827,26 @@ msgid "calculate slope" msgstr "calcular la pendiente" #: src/natcap/invest/routedem.py:99 -#, fuzzy msgid "Calculate the Strahler Stream order." -msgstr "calcular la distancia a la corriente" +msgstr "Calcular la distancia a la corriente." #: src/natcap/invest/routedem.py:100 -#, fuzzy msgid "calculate strahler stream orders (D8 only)" -msgstr "calcular la distancia a la corriente" +msgstr "calcular órdenes de corriente de strahler (solo D8)" #: src/natcap/invest/routedem.py:105 msgid "Determine subwatersheds from the stream order." -msgstr "" +msgstr "Determinar las subcuencas a partir del orden de las corrientes." #: src/natcap/invest/routedem.py:106 -#, fuzzy msgid "calculate subwatersheds (D8 only)" -msgstr "calcular ls corrientes" +msgstr "calcular las corrientes (solamente D8)" #: src/natcap/invest/scenario_gen_proximity.py:28 #, fuzzy msgid "" -"One or more of \"convert_nearest_to_edge\" or " -"\"convert_farthest_from_edge\" must be selected" +"One or more of \"convert_nearest_to_edge\" or \"convert_farthest_from_edge\" " +"must be selected" msgstr "" "Debe seleccionarse una o varias de las opciones " "\"convertir_más_cercano_al_borde\" o \"convertir_más_alejado_del_borde\"" @@ -1934,13 +1878,12 @@ msgstr "superficie máxima a convertir" #: src/natcap/invest/scenario_gen_proximity.py:61 #, fuzzy msgid "" -"A space-separated list of LULC codes that are used to determine the " -"proximity when referring to 'towards' or 'away' from the base landcover " -"codes" +"A space-separated list of LULC codes that are used to determine the proximity " +"when referring to 'towards' or 'away' from the base landcover codes" msgstr "" "Una lista separada por espacios de los códigos LULC que se utilizan para " -"determinar la proximidad cuando se refiere a \"hacia\" o \"lejos\" de los" -" códigos de la cobertura del suelo base" +"determinar la proximidad cuando se refiere a \"hacia\" o \"lejos\" de los " +"códigos de la cobertura del suelo base" #: src/natcap/invest/scenario_gen_proximity.py:65 msgid "focal landcover codes" @@ -1948,11 +1891,11 @@ msgstr "códigos focales de la cubierta vegetal" #: src/natcap/invest/scenario_gen_proximity.py:70 msgid "" -"A space-separated list of LULC codes that can be converted to be " -"converted to agriculture." +"A space-separated list of LULC codes that can be converted to be converted to " +"agriculture." msgstr "" -"Una lista separada por espacios de los códigos LULC que pueden ser " -"convertidos a la agricultura." +"Una lista separada por espacios de los códigos LULC que pueden ser convertidos a " +"la agricultura." #: src/natcap/invest/scenario_gen_proximity.py:73 msgid "convertible landcover codes" @@ -1960,20 +1903,18 @@ msgstr "códigos de la cubierta terrestre convertibles" #: src/natcap/invest/scenario_gen_proximity.py:79 msgid "" -"The number of steps that the simulation should take to fragment the " -"habitat of interest in the fragmentation scenario. This parameter is used" -" to divide the conversion simulation into equal subareas of the requested" -" max area. During each sub-step the distance transform is recalculated " -"from the base landcover codes. This can affect the final result if the " -"base types are also convertible types." -msgstr "" -"El número de pasos que debe dar la simulación para fragmentar el hábitat " -"de interés en el escenario de fragmentación. Este parámetro se utiliza " -"para dividir la simulación de conversión en subáreas iguales del área " -"máxima solicitada. Durante cada subpaso, la transformación de la " -"distancia se recalcula a partir de los códigos de la cobertura del suelo " -"base. Esto puede afectar el resultado final si los tipos base son también" -" tipos convertibles." +"The number of steps that the simulation should take to fragment the habitat of " +"interest in the fragmentation scenario. This parameter is used to divide the " +"conversion simulation into equal subareas of the requested max area. During each " +"sub-step the distance transform is recalculated from the base landcover codes. " +"This can affect the final result if the base types are also convertible types." +msgstr "" +"El número de pasos que debe dar la simulación para fragmentar el hábitat de " +"interés en el escenario de fragmentación. Este parámetro se utiliza para dividir " +"la simulación de conversión en subáreas iguales del área máxima solicitada. " +"Durante cada subpaso, la transformación de la distancia se recalcula a partir de " +"los códigos de la cobertura del suelo base. Esto puede afectar el resultado " +"final si los tipos base son también tipos convertibles." #: src/natcap/invest/scenario_gen_proximity.py:87 msgid "number of conversion steps" @@ -1981,20 +1922,20 @@ msgstr "número de pasos de conversión" #: src/natcap/invest/scenario_gen_proximity.py:92 msgid "" -"Area over which to run the conversion. Provide this input if change is " -"only desired in a subregion of the Base LULC map." +"Area over which to run the conversion. Provide this input if change is only " +"desired in a subregion of the Base LULC map." msgstr "" -"Área sobre la que se va a realizar la conversión. Proporcione este input " -"si solo desea un cambio en una subregión del mapa LULC base." +"Área sobre la que se va a realizar la conversión. Proporcione este input si solo " +"desea un cambio en una subregión del mapa LULC base." #: src/natcap/invest/scenario_gen_proximity.py:98 msgid "" -"Convert the 'convertible' landcover codes starting at the furthest pixel " -"from the 'focal' land cover areas and working inwards." +"Convert the 'convertible' landcover codes starting at the furthest pixel from " +"the 'focal' land cover areas and working inwards." msgstr "" -"Convierta los códigos de cobertura del suelo \"convertibles\" empezando " -"por el píxel más alejado de las zonas de cobertura del suelo \"focales\" " -"y trabajando hacia el interior." +"Convierta los códigos de cobertura del suelo \"convertibles\" empezando por el " +"píxel más alejado de las zonas de cobertura del suelo \"focales\" y trabajando " +"hacia el interior." #: src/natcap/invest/scenario_gen_proximity.py:102 msgid "convert farthest from edge" @@ -2002,12 +1943,12 @@ msgstr "convertir más lejos del borde" #: src/natcap/invest/scenario_gen_proximity.py:106 msgid "" -"Convert the 'convertible' landcover codes starting at the nearest pixels " -"to the 'focal' land cover areas and working outwards." +"Convert the 'convertible' landcover codes starting at the nearest pixels to the " +"'focal' land cover areas and working outwards." msgstr "" -"Convierta los códigos de la cubierta terrestre \"convertible\" empezando " -"por los píxeles más cercanos a las zonas de la cubierta terrestre " -"\"focal\" y trabajando hacia fuera." +"Convierta los códigos de la cubierta terrestre \"convertible\" empezando por los " +"píxeles más cercanos a las zonas de la cubierta terrestre \"focal\" y trabajando " +"hacia fuera." #: src/natcap/invest/scenario_gen_proximity.py:110 msgid "convert nearest to edge" @@ -2015,34 +1956,38 @@ msgstr "convertir lo más cercano al borde" #: src/natcap/invest/scenario_gen_proximity.py:115 msgid "Map of the nearest-to-edge conversion scenario." -msgstr "" +msgstr "Mapa del escenario de conversión más cercano al borde." #: src/natcap/invest/scenario_gen_proximity.py:119 msgid "Map of the farthest-from-edge conversion scenario." -msgstr "" +msgstr "Mapa del escenario de conversión más lejano al borde." #: src/natcap/invest/scenario_gen_proximity.py:123 #: src/natcap/invest/scenario_gen_proximity.py:143 msgid "" -"Table of land cover classes and the amount of each that was converted for" -" the nearest-to-edge conversion scenario." +"Table of land cover classes and the amount of each that was converted for the " +"nearest-to-edge conversion scenario." msgstr "" +"Tabla de clases de cobertura del suelo y la cantidad de cada una que se " +"convirtió para el escenario de conversi´pn mas-cercano-al-borde." #: src/natcap/invest/scenario_gen_proximity.py:166 msgid "Copy of the LULC raster masked to the AOI extent." -msgstr "" +msgstr "Copia del ráster LULC enmascarado para le extensión AOI." #: src/natcap/invest/scenario_gen_proximity.py:171 msgid "" -"Map of the distance from each pixel to the farthest edge of the focal " -"landcover." +"Map of the distance from each pixel to the farthest edge of the focal landcover." msgstr "" +"Mapa de la distancia de cada píxel al borde más alejado de la cubierta vegetal " +"focal." #: src/natcap/invest/scenario_gen_proximity.py:177 msgid "" -"Map of the distance from each pixel to the nearest edge of the focal " -"landcover." +"Map of the distance from each pixel to the nearest edge of the focal landcover." msgstr "" +"Mapa de la distancia de cada píxel al borde más cercano de la cubierta vegetal " +"focal." #: src/natcap/invest/spec_utils.py:12 msgid "workspace" @@ -2050,13 +1995,13 @@ msgstr "espacio de trabajo" #: src/natcap/invest/spec_utils.py:13 msgid "" -"The folder where all the model's output files will be written. If this " -"folder does not exist, it will be created. If data already exists in the " -"folder, it will be overwritten." +"The folder where all the model's output files will be written. If this folder " +"does not exist, it will be created. If data already exists in the folder, it " +"will be overwritten." msgstr "" -"La carpeta donde se escribirán todos los archivos resultantes del modelo." -" Si esta carpeta no existe, se creará. Si los datos ya existen en la " -"carpeta, se sobrescribirán." +"La carpeta donde se escribirán todos los archivos resultantes del modelo. Si " +"esta carpeta no existe, se creará. Si los datos ya existen en la carpeta, se " +"sobrescribirán." #: src/natcap/invest/spec_utils.py:24 msgid "file suffix" @@ -2064,30 +2009,29 @@ msgstr "sufijo del archivo" #: src/natcap/invest/spec_utils.py:25 msgid "" -"Suffix that will be appended to all output file names. Useful to " -"differentiate between model runs." +"Suffix that will be appended to all output file names. Useful to differentiate " +"between model runs." msgstr "" -"Sufijo que se añadirá a todos los nombres de archivos resultantes. Es " -"útil para diferenciar entre las ejecuciones del modelo." +"Sufijo que se añadirá a todos los nombres de archivos resultantes. Es útil para " +"diferenciar entre las ejecuciones del modelo." #: src/natcap/invest/spec_utils.py:34 -#, fuzzy msgid "taskgraph n_workers parameter" -msgstr "Parámetro n_workers del gráfico de tareas" +msgstr "parámetro n_workers del gráfico de tareas" #: src/natcap/invest/spec_utils.py:35 #, fuzzy msgid "" -"The n_workers parameter to provide to taskgraph. -1 will cause all jobs " -"to run synchronously. 0 will run all jobs in the same process, but " -"scheduling will take place asynchronously. Any other positive integer " -"will cause that many processes to be spawned to execute tasks." +"The n_workers parameter to provide to taskgraph. -1 will cause all jobs to run " +"synchronously. 0 will run all jobs in the same process, but scheduling will take " +"place asynchronously. Any other positive integer will cause that many processes " +"to be spawned to execute tasks." msgstr "" "El parámetro n_workers a proporcionar a taskgraph. -1 hará que todos los " -"trabajos se ejecuten de forma sincrónica. 0 hará que todos los trabajos " -"se ejecuten en el mismo proceso, pero la programación tendrá lugar de " -"forma asíncrona. Cualquier otro número entero positivo hará que se " -"generen ese número de procesos para ejecutar las tareas." +"trabajos se ejecuten de forma sincrónica. 0 hará que todos los trabajos se " +"ejecuten en el mismo proceso, pero la programación tendrá lugar de forma " +"asíncrona. Cualquier otro número entero positivo hará que se generen ese número " +"de procesos para ejecutar las tareas." #: src/natcap/invest/spec_utils.py:60 msgid "area of interest" @@ -2099,9 +2043,11 @@ msgstr "Un mapa de zonas sobre el que agregar y resumir los resultados finales." #: src/natcap/invest/spec_utils.py:68 msgid "" -"Map of land use/land cover codes. Each land use/land cover type must be " -"assigned a unique integer code." +"Map of land use/land cover codes. Each land use/land cover type must be assigned " +"a unique integer code." msgstr "" +"Mapa de códigos de uso/cobertura del suelo. A cada tipo de uso del suelo/" +"cobertura del suelo se le debe asignar un código entero único." #: src/natcap/invest/spec_utils.py:71 msgid "land use/land cover" @@ -2136,9 +2082,9 @@ msgid "" "Map of soil hydrologic groups. Pixels may have values 1, 2, 3, or 4, " "corresponding to soil hydrologic groups A, B, C, or D, respectively." msgstr "" -"Mapa de los grupos hidrológicos del suelo. Los píxeles pueden tener los " -"valores 1, 2, 3 o 4, correspondientes a los grupos hidrológicos de suelo " -"A, B, C o D, respectivamente." +"Mapa de los grupos hidrológicos del suelo. Los píxeles pueden tener los valores " +"1, 2, 3 o 4, correspondientes a los grupos hidrológicos de suelo A, B, C o D, " +"respectivamente." #: src/natcap/invest/spec_utils.py:112 msgid "soil hydrologic group" @@ -2146,11 +2092,11 @@ msgstr "grupo hidrológico del suelo" #: src/natcap/invest/spec_utils.py:118 msgid "" -"The number of upslope pixels that must flow into a pixel before it is " -"classified as a stream." +"The number of upslope pixels that must flow into a pixel before it is classified " +"as a stream." msgstr "" -"El número de píxeles pendiente arriba que deben fluir en un píxel antes " -"de que se clasifique como una corriente." +"El número de píxeles pendiente arriba que deben fluir en un píxel antes de que " +"se clasifique como una corriente." #: src/natcap/invest/spec_utils.py:121 msgid "threshold flow accumulation" @@ -2158,50 +2104,51 @@ msgstr "umbral de acumulación de flujo" #: src/natcap/invest/spec_utils.py:125 #: src/natcap/invest/urban_flood_risk_mitigation.py:64 -#, fuzzy msgid "LULC codes from the LULC raster. Each code must be a unique integer." -msgstr "Código LULC del ráster LULC." +msgstr "Código LULC del ráster LULC. Cada código debe ser un número entero único." #: src/natcap/invest/spec_utils.py:141 msgid "Map of elevation after any pits are filled" -msgstr "" +msgstr "Mapa de elevación después de rellenar las fosas" #: src/natcap/invest/spec_utils.py:148 -#, fuzzy msgid "Map of flow accumulation" -msgstr "umbral de acumulación de flujo" +msgstr "Umbral de acumulación de flujo" #: src/natcap/invest/spec_utils.py:155 msgid "" -"MFD flow direction. Note: the pixel values should not be interpreted " -"directly. Each 32-bit number consists of 8 4-bit numbers. Each 4-bit " -"number represents the proportion of flow into one of the eight " -"neighboring pixels." +"MFD flow direction. Note: the pixel values should not be interpreted directly. " +"Each 32-bit number consists of 8 4-bit numbers. Each 4-bit number represents the " +"proportion of flow into one of the eight neighboring pixels." msgstr "" +"La dirección del flujo MFD. Nota: los valores de los píxeles no deben " +"interpretarse directamente. Cada número de 32 bits se compone de 8 números de 4 " +"bits. Cada número de 4 bits representa la proporción de flujo en uno de los ocho " +"píxeles vecinos." #: src/natcap/invest/spec_utils.py:164 -#, fuzzy msgid "D8 flow direction." -msgstr "cálcular la dirección del flujo" +msgstr "cálcular la dirección del flujo." #: src/natcap/invest/spec_utils.py:169 msgid "" -"Percent slope, calculated from the pit-filled DEM. 100 is equivalent to a" -" 45 degree slope." +"Percent slope, calculated from the pit-filled DEM. 100 is equivalent to a 45 " +"degree slope." msgstr "" +"El porcentaje de la pendiente, calculado a partir del MDE con fosas rellenadas. " +"100 equivale a una pendiente de 45 grados." #: src/natcap/invest/spec_utils.py:222 -#, fuzzy msgid "number of pixels" -msgstr "número de turbinas" +msgstr "número de píxeles" #: src/natcap/invest/spec_utils.py:231 msgid "unitless" -msgstr "" +msgstr "sin unidades" #: src/natcap/invest/spec_utils.py:251 msgid "currency units" -msgstr "" +msgstr "unidades monetarias" #: src/natcap/invest/spec_utils.py:306 msgid "required" @@ -2277,7 +2224,7 @@ msgstr "vector" #: src/natcap/invest/spec_utils.py:504 msgid "units" -msgstr "" +msgstr "unidades" #: src/natcap/invest/spec_utils.py:533 src/natcap/invest/spec_utils.py:537 msgid "Options:" @@ -2289,12 +2236,12 @@ msgstr " Consulte la tabla de datos de muestra para conocer el formato." #: src/natcap/invest/stormwater.py:56 msgid "" -"Event mean concentration of the pollutant in stormwater. You may include " -"any number of these columns for different pollutants, or none at all." +"Event mean concentration of the pollutant in stormwater. You may include any " +"number of these columns for different pollutants, or none at all." msgstr "" -"Concentración media del contaminante del evento en las aguas pluviales. " -"Puede incluir cualquier número de estas columnas para diferentes " -"contaminantes, o ninguna." +"Concentración media del contaminante del evento en las aguas pluviales. Puede " +"incluir cualquier número de estas columnas para diferentes contaminantes, o " +"ninguna." #: src/natcap/invest/stormwater.py:65 msgid "Stormwater runoff coefficient for soil group" @@ -2307,32 +2254,29 @@ msgstr "Coeficiente de percolación de las aguas pluviales para el grupo de suel #: src/natcap/invest/stormwater.py:84 #, fuzzy msgid "" -"Enter 1 if the LULC class is a connected impervious surface, 0 if not. " -"This column is only used if the 'adjust retention ratios' option is " -"selected. If 'adjust retention ratios' is selected and this column " -"exists, the adjustment algorithm takes into account the LULC as well as " -"road centerlines. If this column does not exist, only the road " -"centerlines are used." -msgstr "" -"Introduzca 1 si la clase LULC es una superficie impermeable conectada, 0 " -"si no lo es. Esta columna solo se utiliza si se selecciona la opción " -"\"ajustar los coeficientes de retención\". Si se selecciona la opción " -"\"ajustar relaciones de retención\" y esta columna existe, el algoritmo " -"de ajuste tiene en cuenta la LULC y las líneas centrales de las " -"carreteras. Si esta columna no existe, solo se utilizan las líneas " -"centrales de las carreteras." +"Enter 1 if the LULC class is a connected impervious surface, 0 if not. This " +"column is only used if the 'adjust retention ratios' option is selected. If " +"'adjust retention ratios' is selected and this column exists, the adjustment " +"algorithm takes into account the LULC as well as road centerlines. If this " +"column does not exist, only the road centerlines are used." +msgstr "" +"Introduzca 1 si la clase LULC es una superficie impermeable conectada, 0 si no " +"lo es. Esta columna solo se utiliza si se selecciona la opción \"ajustar los " +"coeficientes de retención\". Si se selecciona la opción \"ajustar relaciones de " +"retención\" y esta columna existe, el algoritmo de ajuste tiene en cuenta la " +"LULC y las líneas centrales de las carreteras. Si esta columna no existe, solo " +"se utilizan las líneas centrales de las carreteras." #: src/natcap/invest/stormwater.py:95 msgid "" -"Table mapping each LULC code found in the LULC raster to biophysical data" -" about that LULC class. If you provide the percolation coefficient column" -" (PE_[X]) for any soil group, you must provide it for all four soil " -"groups." +"Table mapping each LULC code found in the LULC raster to biophysical data about " +"that LULC class. If you provide the percolation coefficient column (PE_[X]) for " +"any soil group, you must provide it for all four soil groups." msgstr "" -"Tabla que asigna cada código LULC encontrado en el ráster LULC a los " -"datos biofísicos sobre esa clase LULC. Si proporciona la columna del " -"coeficiente de percolación (PE_[X]) para cualquier grupo de suelos, debe " -"proporcionarla para los cuatro grupos de suelos." +"Tabla que asigna cada código LULC encontrado en el ráster LULC a los datos " +"biofísicos sobre esa clase LULC. Si proporciona la columna del coeficiente de " +"percolación (PE_[X]) para cualquier grupo de suelos, debe proporcionarla para " +"los cuatro grupos de suelos." #: src/natcap/invest/stormwater.py:100 msgid "Biophysical table" @@ -2341,20 +2285,18 @@ msgstr "Tabla biofísica" #: src/natcap/invest/stormwater.py:104 #, fuzzy msgid "" -"If true, adjust retention ratios. The adjustment algorithm accounts for " -"drainage effects of nearby impervious surfaces which are directly " -"connected to artifical urban drainage channels (typically roads, parking " -"lots, etc.) Connected impervious surfaces are indicated by the " -"is_connected columnin the biophysical table and/or the road centerlines " -"vector." -msgstr "" -"Si es cierto, ajusta los coeficientes de retención. El algoritmo de " -"ajuste tiene en cuenta los efectos del drenaje de las superficies " -"impermeables cercanas que están directamente conectadas a los canales de " -"drenaje urbano artificiales (normalmente carreteras, estacionamientos, " -"etc.). Las superficies impermeables conectadas se indican mediante la " -"columna is_connected en la tabla biofísica y/o el vector de líneas " -"centrales de carreteras." +"If true, adjust retention ratios. The adjustment algorithm accounts for drainage " +"effects of nearby impervious surfaces which are directly connected to artifical " +"urban drainage channels (typically roads, parking lots, etc.) Connected " +"impervious surfaces are indicated by the is_connected columnin the biophysical " +"table and/or the road centerlines vector." +msgstr "" +"Si es cierto, ajusta los coeficientes de retención. El algoritmo de ajuste tiene " +"en cuenta los efectos del drenaje de las superficies impermeables cercanas que " +"están directamente conectadas a los canales de drenaje urbano artificiales " +"(normalmente carreteras, estacionamientos, etc.). Las superficies impermeables " +"conectadas se indican mediante la columna is_connected en la tabla biofísica y/o " +"el vector de líneas centrales de carreteras." #: src/natcap/invest/stormwater.py:111 msgid "Adjust retention ratios" @@ -2363,15 +2305,15 @@ msgstr "Ajustar las tasas de retención" #: src/natcap/invest/stormwater.py:117 msgid "" "Radius around each pixel to adjust retention ratios. Measured in raster " -"coordinate system units. For the adjustment algorithm, a pixel is 'near' " -"a connected impervious surface if its centerpoint is within this radius " -"of connected-impervious LULC and/or a road centerline." +"coordinate system units. For the adjustment algorithm, a pixel is 'near' a " +"connected impervious surface if its centerpoint is within this radius of " +"connected-impervious LULC and/or a road centerline." msgstr "" -"Radio alrededor de cada píxel para ajustar las relaciones de retención. " -"Medido en unidades del sistema de coordenadas raster. Para el algoritmo " -"de ajuste, un píxel está \"cerca\" de una superficie impermeable " -"conectada si su punto central está dentro de este radio de LULC " -"impermeable conectada y/o una línea central de carretera." +"Radio alrededor de cada píxel para ajustar las relaciones de retención. Medido " +"en unidades del sistema de coordenadas raster. Para el algoritmo de ajuste, un " +"píxel está \"cerca\" de una superficie impermeable conectada si su punto central " +"está dentro de este radio de LULC impermeable conectada y/o una línea central de " +"carretera." #: src/natcap/invest/stormwater.py:123 msgid "Retention radius" @@ -2387,19 +2329,18 @@ msgstr "Líneas centrales de la carretera" #: src/natcap/invest/stormwater.py:136 msgid "" -"Areas over which to aggregate results (typically watersheds or " -"sewersheds). The aggregated data are: average retention ratio and total " -"retention volume; average percolation ratio and total percolation volume " -"if percolation data was provided; total retention value if replacement " -"cost was provided; and total avoided pollutant load for each pollutant " -"provided." +"Areas over which to aggregate results (typically watersheds or sewersheds). The " +"aggregated data are: average retention ratio and total retention volume; average " +"percolation ratio and total percolation volume if percolation data was provided; " +"total retention value if replacement cost was provided; and total avoided " +"pollutant load for each pollutant provided." msgstr "" "Zonas sobre las que se van a agregar los resultados (normalmente cuencas " -"hidrográficas o de alcantarillado). Los datos agregados son: ratio de " -"retención media y volumen de retención total; ratio de percolación media " -"y volumen de percolación total si se facilitan datos de percolación; " -"valor de retención total si se facilita el costo de reposición; y carga " -"contaminante total evitada para cada contaminante facilitado." +"hidrográficas o de alcantarillado). Los datos agregados son: ratio de retención " +"media y volumen de retención total; ratio de percolación media y volumen de " +"percolación total si se facilitan datos de percolación; valor de retención total " +"si se facilita el costo de reposición; y carga contaminante total evitada para " +"cada contaminante facilitado." #: src/natcap/invest/stormwater.py:149 msgid "Replacement cost of stormwater retention devices" @@ -2414,223 +2355,257 @@ msgid "" "Map of the stormwater retention ratio, derived from the LULC raster and " "biophysical table RC_x columns." msgstr "" +"Mapa del coeficiente de retención de aguas pluviales, derivado del ráster LULC y " +"de las columnas RC_x de la tabla biofísica." #: src/natcap/invest/stormwater.py:162 msgid "" -"Map of the adjusted retention ratio, calculated according to equation " -"(124) from the ‘retention_ratio, ratio_average, near_road’, and " -"‘near_impervious_lulc’ intermediate outputs." +"Map of the adjusted retention ratio, calculated according to equation (124) from " +"the ‘retention_ratio, ratio_average, near_road’, and ‘near_impervious_lulc’ " +"intermediate outputs." msgstr "" +"Mapa del coeficiente de retención ajustado, calculado según la ecuación (124) a " +"partir de los resultados intermedios ‘retention_ratio, ratio_average, near_road’ " +"y ‘near_impervious_lulc’ ." #: src/natcap/invest/stormwater.py:169 -#, fuzzy msgid "Map of retention volume." -msgstr "Mapa de valores de evapotranspiración." +msgstr "Mapa de volumen de retención." #: src/natcap/invest/stormwater.py:177 msgid "" -"Map of percolation ratio derived by cross-referencing the LULC and soil " -"group rasters with the biophysical table." +"Map of percolation ratio derived by cross-referencing the LULC and soil group " +"rasters with the biophysical table." msgstr "" +"Mapa del coeficiente de percolación derivado de las referencias cruzadas de los " +"rásters LULC y de grupos de suelos con la tabla biofísica." #: src/natcap/invest/stormwater.py:184 msgid "Map of percolation (potential aquifer recharge) volume." -msgstr "" +msgstr "Mapa del volumen de percolación (recarga potencial del acuífero)." #: src/natcap/invest/stormwater.py:191 msgid "" -"Map of the stormwater runoff ratio. This is the inverse of " -"‘retention_ratio.tif’" +"Map of the stormwater runoff ratio. This is the inverse of ‘retention_ratio.tif’" msgstr "" +"Mapa del coeficiente de escorrentía de aguas pluviales. Es el inverso de " +"'retention_ratio.tif'." #: src/natcap/invest/stormwater.py:197 msgid "Map of runoff volume." -msgstr "" +msgstr "Mapa del volumen de la escorrentía." #: src/natcap/invest/stormwater.py:205 msgid "Map of the value of water retained." -msgstr "" +msgstr "Mapa del valor del agua retenida." #: src/natcap/invest/stormwater.py:213 msgid "" -"Map of aggregate data. This is identical to the aggregate areas input " -"vector, but each polygon is given additional fields with the aggregate " -"data." +"Map of aggregate data. This is identical to the aggregate areas input vector, " +"but each polygon is given additional fields with the aggregate data." msgstr "" +"Mapa de datos agregados. Es idéntico al vector de entrada de áreas agregadas, " +"pero cada polígono recibe campos adicionales con los datos agregados." #: src/natcap/invest/stormwater.py:221 msgid "Average retention ratio over this polygon" -msgstr "" +msgstr "Tasa media de retención en este polígono" #: src/natcap/invest/stormwater.py:226 msgid "Total retention volume over this polygon" -msgstr "" +msgstr "Volumen total de retención en este polígono" #: src/natcap/invest/stormwater.py:230 -#, fuzzy msgid "Average runoff coefficient over this polygon" -msgstr "Coeficiente de escorrentía de aguas pluviales para el grupo de suelos" +msgstr "Coeficiente medio de escorrentía en este polígono" #: src/natcap/invest/stormwater.py:235 msgid "Total runoff volume over this polygon" -msgstr "" +msgstr "Volumen total de escorrentía en este polígono" #: src/natcap/invest/stormwater.py:239 msgid "Average percolation (recharge) ratio over this polygon" -msgstr "" +msgstr "Tasa media de percolación (recarga) en este polígono" #: src/natcap/invest/stormwater.py:244 msgid "Total volume of potential aquifer recharge over this polygon" -msgstr "" +msgstr "Volumen total de recarga potencial del acuífero para este polígono" #: src/natcap/invest/stormwater.py:249 msgid "Total avoided (retained) amount of pollutant over this polygon" -msgstr "" +msgstr "Cantidad total evitada (retenida) de contaminantes en este polígono" #: src/natcap/invest/stormwater.py:254 msgid "Total amount of pollutant in runoff over this polygon" -msgstr "" +msgstr "Cantidad total de contaminantes en la escorrentía de este polígono" #: src/natcap/invest/stormwater.py:260 msgid "Total value of the retained volume of water over this polygon" -msgstr "" +msgstr "Valor total del volumen de agua retenida en este polígono" #: src/natcap/invest/stormwater.py:270 msgid "" -"Copy of the soil group raster input, cropped to the intersection of the " -"three raster inputs." +"Copy of the soil group raster input, cropped to the intersection of the three " +"raster inputs." msgstr "" +"Copia de la entrada ráster del grupo de suelos, recortada en la intersección de " +"las tres entradas ráster." #: src/natcap/invest/stormwater.py:276 msgid "" -"Copy of the soil group raster input, aligned to the LULC raster and " -"cropped to the intersection of the three raster inputs." +"Copy of the soil group raster input, aligned to the LULC raster and cropped to " +"the intersection of the three raster inputs." msgstr "" +"Copia de la entrada ráster del grupo de suelos, alineada con la entrada ráster " +"LULC y recortada en la intersección de las tres entradas ráster." #: src/natcap/invest/stormwater.py:283 msgid "" -"Copy of the precipitation raster input, aligned to the LULC raster and " -"cropped to the intersection of the three raster inputs." +"Copy of the precipitation raster input, aligned to the LULC raster and cropped " +"to the intersection of the three raster inputs." msgstr "" +"Copia del ráster de precipitaciones, alineada con el ráster LULC y recortada en " +"la intersección de los tres rásters." #: src/natcap/invest/stormwater.py:295 msgid "" -"Copy of the road centerlines vector input, reprojected to the LULC raster" -" projection." +"Copy of the road centerlines vector input, reprojected to the LULC raster " +"projection." msgstr "" +"Copia de la entrada vectorial de las líneas centrales de las carreteras, " +"reproyectada a la proyección ráster LULC." #: src/natcap/invest/stormwater.py:303 msgid "" -"A rasterized version of the reprojected centerlines vector, where 1 means" -" the pixel is a road and 0 means it isn’t." +"A rasterized version of the reprojected centerlines vector, where 1 means the " +"pixel is a road and 0 means it isn’t." msgstr "" +"Una versión rasterizada del vector de líneas centrales reproyectado, donde 1 " +"significa que el píxel es una carretera y 0 significa que no lo es." #: src/natcap/invest/stormwater.py:310 msgid "" -"A binary raster derived from the LULC raster and biophysical table " -"is_connected column, where 1 means the pixel has a directly-connected " -"impervious LULC type, and 0 means it does not." +"A binary raster derived from the LULC raster and biophysical table is_connected " +"column, where 1 means the pixel has a directly-connected impervious LULC type, " +"and 0 means it does not." msgstr "" +"Un ráster binario derivado del ráster LULC y de la columna is_connected de la " +"tabla biofísica, donde 1 significa que el píxel tiene un tipo LULC impermeable " +"directamente conectado, y 0 significa que no lo tiene." #: src/natcap/invest/stormwater.py:318 msgid "" -"A raster derived from the rasterized centerlines map, where each pixel’s " -"value is its minimum distance to a road pixel (measured centerpoint-to-" -"centerpoint)." +"A raster derived from the rasterized centerlines map, where each pixel’s value " +"is its minimum distance to a road pixel (measured centerpoint-to-centerpoint)." msgstr "" +"Un ráster derivado del mapa de líneas centrales rasterizadas, donde el valor de " +"cada píxel es su distancia mínima a un píxel de carretera (medida de punto " +"central a punto central)." #: src/natcap/invest/stormwater.py:328 msgid "" -"A raster derived from the is_connected_lulc map, where each pixel’s value" -" is its minimum distance to a connected impervious LULC pixel (measured " -"centerpoint-to-centerpoint)." +"A raster derived from the is_connected_lulc map, where each pixel’s value is its " +"minimum distance to a connected impervious LULC pixel (measured centerpoint-to-" +"centerpoint)." msgstr "" +"Un ráster derivado del mapa is_connected_lulc, en la que el valor de cada píxel " +"es su distancia mínima a un píxel LULC impermeable conectado (medida de punto " +"central a punto central)." #: src/natcap/invest/stormwater.py:339 msgid "" -"A binary raster derived from the road_distance map, where 1 means the " -"pixel is within the retention radius of a road pixel, and 0 means it " -"isn’t." +"A binary raster derived from the road_distance map, where 1 means the pixel is " +"within the retention radius of a road pixel, and 0 means it isn’t." msgstr "" +"Un ráster binario derivado del mapa road_distance, donde 1 significa que el " +"píxel está dentro del radio de retención de un píxel de carretera, y 0 significa " +"que no lo está." #: src/natcap/invest/stormwater.py:346 msgid "" -"A binary raster derived from the connected_lulc_distance map, where 1 " -"means the pixel is within the retention radius of a connected impervious " -"LULC pixel, and 0 means it isn’t." +"A binary raster derived from the connected_lulc_distance map, where 1 means the " +"pixel is within the retention radius of a connected impervious LULC pixel, and 0 " +"means it isn’t." msgstr "" +"Un ráster binario derivado del mapa connected_lulc_distance, donde 1 significa " +"que el píxel está dentro del radio de retención de un píxel LULC impermeable " +"conectado, y 0 significa que no lo está." #: src/natcap/invest/stormwater.py:354 msgid "" -"A binary raster representing the search kernel that is convolved with the" -" retention_ratio raster to calculate the averaged retention ratio within " -"the retention radius of each pixel." +"A binary raster representing the search kernel that is convolved with the " +"retention_ratio raster to calculate the averaged retention ratio within the " +"retention radius of each pixel." msgstr "" +"Un ráster binario que representa el núcleo de búsqueda que se convoluciona con " +"el ráster retention_ratio para calcular la relación de retención promediada " +"dentro del radio de retención de cada píxel." #: src/natcap/invest/stormwater.py:362 msgid "" -"A raster where each pixel’s value is the average of its neighborhood of " -"pixels in the retention_ratio map, calculated by convolving the search " -"kernel with the retention ratio raster." +"A raster where each pixel’s value is the average of its neighborhood of pixels " +"in the retention_ratio map, calculated by convolving the search kernel with the " +"retention ratio raster." msgstr "" +"Un ráster en que el valor de cada píxel es la media de su vecindad de píxeles en " +"el mapa retention_ratio, calculado mediante la convolución del núcleo de " +"búsqueda con la trama de tasa de retención." #: src/natcap/invest/urban_cooling_model.py:49 msgid "" -"Map of LULC for the area of interest. All values in this raster must have" -" corresponding entries in the Biophysical Table." +"Map of LULC for the area of interest. All values in this raster must have " +"corresponding entries in the Biophysical Table." msgstr "" -"Mapa de LULC para el área de interés. Todos los valores de este ráster " -"deben tener los inputs correspondientes en la Tabla Biofísica." +"Mapa de LULC para el área de interés. Todos los valores de este ráster deben " +"tener los inputs correspondientes en la Tabla Biofísica." #: src/natcap/invest/urban_cooling_model.py:68 msgid "" "Enter 1 to indicate that the LULC is considered a green area. Enter 0 to " "indicate that the LULC is not considered a green area." msgstr "" -"Introduzca 1 para indicar que el LULC se considera una zona verde. " -"Introduzca 0 para indicar que el LULC no se considera una zona verde." +"Introduzca 1 para indicar que el LULC se considera una zona verde. Introduzca 0 " +"para indicar que el LULC no se considera una zona verde." #: src/natcap/invest/urban_cooling_model.py:75 msgid "" -"The proportion of area in this LULC class that is covered by tree canopy " -"at least 2 meters high. Required if the 'factors' option is selected for " -"the Cooling Capacity Calculation Method." +"The proportion of area in this LULC class that is covered by tree canopy at " +"least 2 meters high. Required if the 'factors' option is selected for the " +"Cooling Capacity Calculation Method." msgstr "" -"Proporción de la superficie de esta clase de LULC que está cubierta por " -"un dosel de árboles de al menos 2 metros de altura. Necesario si se " -"selecciona la opción \"factores\" para el método de cálculo de la " -"capacidad de enfriamiento." +"Proporción de la superficie de esta clase de LULC que está cubierta por un dosel " +"de árboles de al menos 2 metros de altura. Necesario si se selecciona la opción " +"\"factores\" para el método de cálculo de la capacidad de enfriamiento." #: src/natcap/invest/urban_cooling_model.py:83 msgid "" -"The proportion of solar radiation that is directly reflected by this LULC" -" class. Required if the 'factors' option is selected for the Cooling " -"Capacity Calculation Method." +"The proportion of solar radiation that is directly reflected by this LULC class. " +"Required if the 'factors' option is selected for the Cooling Capacity " +"Calculation Method." msgstr "" -"Proporción de la radiación solar que refleja directamente esta clase de " -"LULC. Necesaria si se selecciona la opción \"factores\" para el método de" -" cálculo de la capacidad de enfriamiento." +"Proporción de la radiación solar que refleja directamente esta clase de LULC. " +"Necesaria si se selecciona la opción \"factores\" para el método de cálculo de " +"la capacidad de enfriamiento." #: src/natcap/invest/urban_cooling_model.py:91 msgid "" -"The ratio of building floor area to footprint area, with all values in " -"this column normalized between 0 and 1. Required if the 'intensity' " -"option is selected for the Cooling Capacity Calculation Method." +"The ratio of building floor area to footprint area, with all values in this " +"column normalized between 0 and 1. Required if the 'intensity' option is " +"selected for the Cooling Capacity Calculation Method." msgstr "" -"La relación entre la superficie de piso de la construcción y la " -"superficie de la huella, con todos los valores de esta columna " -"normalizados entre 0 y 1. Necesaria si se selecciona la opción " -"\"intensidad\" para el método de cálculo de la capacidad de enfriamiento." +"La relación entre la superficie de piso de la construcción y la superficie de " +"la huella, con todos los valores de esta columna normalizados entre 0 y 1. " +"Necesaria si se selecciona la opción \"intensidad\" para el método de cálculo de " +"la capacidad de enfriamiento." #: src/natcap/invest/urban_cooling_model.py:98 msgid "" -"A table mapping each LULC code to biophysical data for that LULC class. " -"All values in the LULC raster must have corresponding entries in this " -"table." +"A table mapping each LULC code to biophysical data for that LULC class. All " +"values in the LULC raster must have corresponding entries in this table." msgstr "" -"Una tabla que asigna cada código LULC a los datos biofísicos de esa clase" -" LULC. Todos los valores del ráster LULC deben tener los inputs " -"correspondientes en esta tabla." +"Una tabla que asigna cada código LULC a los datos biofísicos de esa clase LULC. " +"Todos los valores del ráster LULC deben tener los inputs correspondientes en " +"esta tabla." #: src/natcap/invest/urban_cooling_model.py:107 msgid "maximum cooling distance" @@ -2638,11 +2613,10 @@ msgstr "distancia máxima de enfriamiento" #: src/natcap/invest/urban_cooling_model.py:108 msgid "" -"Distance over which green areas larger than 2 hectares have a cooling " -"effect." +"Distance over which green areas larger than 2 hectares have a cooling effect." msgstr "" -"Distancia en la que las zonas verdes de más de 2 hectáreas tienen un " -"efecto refrigerante." +"Distancia en la que las zonas verdes de más de 2 hectáreas tienen un efecto " +"refrigerante." #: src/natcap/invest/urban_cooling_model.py:116 msgid "air blending distance" @@ -2651,8 +2625,8 @@ msgstr "distancia de mezcla de aire" #: src/natcap/invest/urban_cooling_model.py:117 msgid "Radius over which to average air temperatures to account for air mixing." msgstr "" -"Radio sobre el que se promedian las temperaturas del aire para considerar" -" la mezcla del aire." +"Radio sobre el que se promedian las temperaturas del aire para considerar la " +"mezcla del aire." #: src/natcap/invest/urban_cooling_model.py:122 msgid "reference air temperature" @@ -2660,11 +2634,11 @@ msgstr "temperatura del aire de referencia" #: src/natcap/invest/urban_cooling_model.py:125 msgid "" -"Air temperature in a rural reference area where the urban heat island " -"effect is not observed." +"Air temperature in a rural reference area where the urban heat island effect is " +"not observed." msgstr "" -"Temperatura del aire en una zona rural de referencia en la que no se " -"observa el efecto de isla de calor urbana." +"Temperatura del aire en una zona rural de referencia en la que no se observa el " +"efecto de isla de calor urbana." #: src/natcap/invest/urban_cooling_model.py:130 msgid "UHI effect" @@ -2672,13 +2646,11 @@ msgstr "Efecto isla de calor urbana" #: src/natcap/invest/urban_cooling_model.py:133 msgid "" -"The magnitude of the urban heat island effect, i.e., the difference " -"between the rural reference temperature and the maximum temperature " -"observed in the city." +"The magnitude of the urban heat island effect, i.e., the difference between the " +"rural reference temperature and the maximum temperature observed in the city." msgstr "" -"La magnitud del efecto isla de calor urbana, es decir, la diferencia " -"entre la temperatura de referencia rural y la temperatura máxima " -"observada en la ciudad." +"La magnitud del efecto isla de calor urbana, es decir, la diferencia entre la " +"temperatura de referencia rural y la temperatura máxima observada en la ciudad." #: src/natcap/invest/urban_cooling_model.py:139 msgid "run energy savings valuation" @@ -2702,12 +2674,11 @@ msgstr "humedad relativa media" #: src/natcap/invest/urban_cooling_model.py:152 msgid "" -"The average relative humidity over the time period of interest. Required " -"if Run Work Productivity Valuation is selected." +"The average relative humidity over the time period of interest. Required if Run " +"Work Productivity Valuation is selected." msgstr "" -"La humedad relativa media durante el período de tiempo de interés. " -"Requerida si se selecciona la opción de ejecutar valoración de la " -"productividad del trabajo." +"La humedad relativa media durante el período de tiempo de interés. Requerida si " +"se selecciona la opción de ejecutar valoración de la productividad del trabajo." #: src/natcap/invest/urban_cooling_model.py:158 msgid "buildings" @@ -2715,19 +2686,19 @@ msgstr "construcciones" #: src/natcap/invest/urban_cooling_model.py:163 msgid "" -"Code indicating the building type. These codes must match those in the " -"Energy Consumption Table." +"Code indicating the building type. These codes must match those in the Energy " +"Consumption Table." msgstr "" -"Código que indica el tipo de construcción. Estos códigos deben coincidir " -"con los de la tabla de consumo energético." +"Código que indica el tipo de construcción. Estos códigos deben coincidir con los " +"de la tabla de consumo energético." #: src/natcap/invest/urban_cooling_model.py:168 msgid "" "A map of built infrastructure footprints. Required if Run Energy Savings " "Valuation is selected." msgstr "" -"Un mapa de las huellas de las infraestructuras construidas. Se necesita " -"si se selecciona la opción de ejecutar valoración del ahorro de energía." +"Un mapa de las huellas de las infraestructuras construidas. Se necesita si se " +"selecciona la opción de ejecutar valoración del ahorro de energía." #: src/natcap/invest/urban_cooling_model.py:173 msgid "energy consumption table" @@ -2737,33 +2708,30 @@ msgstr "tabla de consumo de energía" #, fuzzy msgid "Building type codes matching those in the Buildings vector." msgstr "" -"Códigos de tipo de construcción que coinciden con los del vector " -"Buildings." +"Códigos de tipo de construcción que coinciden con los del vector Buildings." #: src/natcap/invest/urban_cooling_model.py:186 msgid "Energy consumption by footprint area for this building type." msgstr "" -"Consumo de energía por superficie de la huella para este tipo de " -"construcción." +"Consumo de energía por superficie de la huella para este tipo de construcción." #: src/natcap/invest/urban_cooling_model.py:194 msgid "" -"The cost of electricity for this building type. If this column is " -"provided, the energy savings outputs will be in the this currency unit " -"rather than kWh." +"The cost of electricity for this building type. If this column is provided, the " +"energy savings outputs will be in the this currency unit rather than kWh." msgstr "" -"El costo de la electricidad para este tipo de construcción. Si se " -"proporciona esta columna, los resultados de ahorro de energía estarán en " -"esta unidad monetaria en lugar de en kWh." +"El costo de la electricidad para este tipo de construcción. Si se proporciona " +"esta columna, los resultados de ahorro de energía estarán en esta unidad " +"monetaria en lugar de en kWh." #: src/natcap/invest/urban_cooling_model.py:202 msgid "" -"A table of energy consumption data for each building type. Required if " -"Run Energy Savings Valuation is selected." +"A table of energy consumption data for each building type. Required if Run " +"Energy Savings Valuation is selected." msgstr "" -"Una tabla de datos de consumo de energía para cada tipo de construcción. " -"Se necesita si se selecciona la opción de ejecutar la valoración del " -"ahorro de energía." +"Una tabla de datos de consumo de energía para cada tipo de construcción. Se " +"necesita si se selecciona la opción de ejecutar la valoración del ahorro de " +"energía." #: src/natcap/invest/urban_cooling_model.py:207 msgid "cooling capacity calculation method" @@ -2776,11 +2744,11 @@ msgstr "factores" #: src/natcap/invest/urban_cooling_model.py:212 #, fuzzy msgid "" -"Use the weighted shade, albedo, and ETI factors as a temperature " -"predictor (for daytime temperatures)." +"Use the weighted shade, albedo, and ETI factors as a temperature predictor (for " +"daytime temperatures)." msgstr "" -"Utilizar los factores ponderados de sombra, albedo e IET como predictor " -"de temperatura (para las temperaturas diurnas)." +"Utilizar los factores ponderados de sombra, albedo e IET como predictor de " +"temperatura (para las temperaturas diurnas)." #: src/natcap/invest/urban_cooling_model.py:216 msgid "intensity" @@ -2788,11 +2756,10 @@ msgstr "intensidad" #: src/natcap/invest/urban_cooling_model.py:217 msgid "" -"Use building intensity as a temperature predictor (for nighttime " -"temperatures)." +"Use building intensity as a temperature predictor (for nighttime temperatures)." msgstr "" -"Utilizar la intensidad de construcción como predictor de la temperatura " -"(para las temperaturas nocturnas)." +"Utilizar la intensidad de construcción como predictor de la temperatura (para " +"las temperaturas nocturnas)." #: src/natcap/invest/urban_cooling_model.py:221 msgid "The air temperature predictor method to use." @@ -2804,12 +2771,11 @@ msgstr "peso de la sombra" #: src/natcap/invest/urban_cooling_model.py:227 msgid "" -"The relative weight to apply to shade when calculating the cooling " -"capacity index. If not provided, defaults to 0.6." +"The relative weight to apply to shade when calculating the cooling capacity " +"index. If not provided, defaults to 0.6." msgstr "" -"La ponderación relativa que se aplica a la sombra cuando se calcula el " -"índice de capacidad de enfriamiento. Si no se proporciona, el valor " -"predeterminado es 0.6." +"La ponderación relativa que se aplica a la sombra cuando se calcula el índice de " +"capacidad de enfriamiento. Si no se proporciona, el valor predeterminado es 0.6." #: src/natcap/invest/urban_cooling_model.py:232 msgid "albedo weight" @@ -2817,12 +2783,11 @@ msgstr "poneración del albedo" #: src/natcap/invest/urban_cooling_model.py:235 msgid "" -"The relative weight to apply to albedo when calculating the cooling " -"capacity index. If not provided, defaults to 0.2." +"The relative weight to apply to albedo when calculating the cooling capacity " +"index. If not provided, defaults to 0.2." msgstr "" -"La ponderación relativa que se aplica al albedo cuando se calcula el " -"índice de capacidad de enfriamiento. Si no se proporciona, el valor " -"predeterminado es 0.2." +"La ponderación relativa que se aplica al albedo cuando se calcula el índice de " +"capacidad de enfriamiento. Si no se proporciona, el valor predeterminado es 0.2." #: src/natcap/invest/urban_cooling_model.py:240 msgid "evapotranspiration weight" @@ -2830,12 +2795,11 @@ msgstr "ponderación de la evapotranspiración" #: src/natcap/invest/urban_cooling_model.py:243 msgid "" -"The relative weight to apply to ETI when calculating the cooling capacity" -" index. If not provided, defaults to 0.2." +"The relative weight to apply to ETI when calculating the cooling capacity index. " +"If not provided, defaults to 0.2." msgstr "" -"La ponderación relativa que se aplicará al IET cuando se calcule el " -"índice de capacidad de enfriamiento. Si no se proporciona, el valor " -"predeterminado es 0.2." +"La ponderación relativa que se aplicará al IET cuando se calcule el índice de " +"capacidad de enfriamiento. Si no se proporciona, el valor predeterminado es 0.2." #: src/natcap/invest/urban_flood_risk_mitigation.py:44 msgid "Depth of rainfall for the design storm of interest." @@ -2847,8 +2811,8 @@ msgstr "profundidad de la precipitación" #: src/natcap/invest/urban_flood_risk_mitigation.py:50 msgid "" -"Map of LULC. All values in this raster must have corresponding entries in" -" the Biophysical Table." +"Map of LULC. All values in this raster must have corresponding entries in the " +"Biophysical Table." msgstr "" "Mapa de LULC. Todos los valores de este ráster deben tener los inputs " "correspondientes en la tabla biofísica." @@ -2856,27 +2820,26 @@ msgstr "" #: src/natcap/invest/urban_flood_risk_mitigation.py:68 msgid "The curve number value for this LULC type in the soil group code" msgstr "" -"El valor del número de curva para este tipo de LULC en el código de grupo" -" de suelos" +"El valor del número de curva para este tipo de LULC en el código de grupo de " +"suelos" #: src/natcap/invest/urban_flood_risk_mitigation.py:73 msgid "" -"Table of curve number data for each LULC class. All LULC codes in the " -"LULC raster must have corresponding entries in this table for each soil " -"group." +"Table of curve number data for each LULC class. All LULC codes in the LULC " +"raster must have corresponding entries in this table for each soil group." msgstr "" -"Tabla de datos del número de curva para cada clase LULC. Todos los " -"códigos LULC en el raster LULC deben tener los inputs correspondientes en" -" esta tabla para cada grupo de suelos." +"Tabla de datos del número de curva para cada clase LULC. Todos los códigos LULC " +"en el raster LULC deben tener los inputs correspondientes en esta tabla para " +"cada grupo de suelos." #: src/natcap/invest/urban_flood_risk_mitigation.py:84 #, fuzzy msgid "" -"Code indicating the building type. These codes must match those in the " -"Damage Loss Table." +"Code indicating the building type. These codes must match those in the Damage " +"Loss Table." msgstr "" -"Código que indica el tipo de construcción. Estos códigos deben coincidir " -"con los de la Tabla de Pérdidas por Daños." +"Código que indica el tipo de construcción. Estos códigos deben coincidir con los " +"de la Tabla de Pérdidas por Daños." #: src/natcap/invest/urban_flood_risk_mitigation.py:90 msgid "Map of building footprints." @@ -2896,16 +2859,14 @@ msgstr "Pérdida potencial de daños para este tipo de construcción." #: src/natcap/invest/urban_flood_risk_mitigation.py:106 msgid "" -"Table of potential damage loss data for each building type. All values in" -" the Built Infrastructure vector 'type' field must have corresponding " -"entries in this table. Required if the Built Infrastructure vector is " -"provided." +"Table of potential damage loss data for each building type. All values in the " +"Built Infrastructure vector 'type' field must have corresponding entries in this " +"table. Required if the Built Infrastructure vector is provided." msgstr "" -"Tabla de datos de pérdidas de daños potenciales para cada tipo de " -"construcción. Todos los valores del campo \"tipo\" del vector " -"Infraestructura construida deben tener los inputs correspondientes en " -"esta tabla. Obligatorio si se proporciona el vector Infraestructura " -"construida." +"Tabla de datos de pérdidas de daños potenciales para cada tipo de construcción. " +"Todos los valores del campo \"tipo\" del vector Infraestructura construida deben " +"tener los inputs correspondientes en esta tabla. Obligatorio si se proporciona " +"el vector Infraestructura construida." #: src/natcap/invest/urban_flood_risk_mitigation.py:111 msgid "damage loss table" @@ -2913,223 +2874,294 @@ msgstr "tabla de pérdidas por daños" #: src/natcap/invest/urban_nature_access.py:130 msgid "" -"The proportion of the population within each administrative unit " -"belonging to the identified population group (POP_GROUP). At least one " -"column with the prefix 'pop_' is required when aggregating output by " -"population groups." +"The proportion of the population within each administrative unit belonging to " +"the identified population group (POP_GROUP). At least one column with the prefix " +"'pop_' is required when aggregating output by population groups." msgstr "" +"Proporción de la población de cada unidad administrativa que pertenece al grupo " +"de población identificado (POP_GROUP). Se requiere al menos una columna con el " +"prefijo \"pop_\" cuando se agrega el resultado por grupos de población." #: src/natcap/invest/urban_nature_access.py:139 msgid "" -"A vector representing administrative units. Polygons representing " -"administrative units should not overlap. Overlapping administrative " -"geometries may cause unexpected results and for this reason should not " -"overlap." +"A vector representing administrative units. Polygons representing administrative " +"units should not overlap. Overlapping administrative geometries may cause " +"unexpected results and for this reason should not overlap." msgstr "" +"Un vector que representa unidades administrativas. Los polígonos que representan " +"unidades administrativas no deben solaparse. La superposición de geometrías " +"administrativas puede causar resultados inesperados y por esta razón no deben " +"superponerse." #: src/natcap/invest/urban_nature_access.py:151 msgid "" -"The amount of urban nature that each resident should have access to. This" -" is often defined by local urban planning documents." +"The amount of urban nature that each resident should have access to. This is " +"often defined by local urban planning documents." msgstr "" +"La cantidad de naturaleza urbana a la que debe tener acceso cada residente. " +"Suele definirse en los documentos urbanísticos locales." #: src/natcap/invest/urban_nature_access.py:163 msgid "" -"All pixels within the search radius contribute equally to an urban nature" -" pixel." +"All pixels within the search radius contribute equally to an urban nature pixel." msgstr "" +"Todos los píxeles dentro del radio de búsqueda contribuyen por igual a un píxel " +"de naturaleza urbana." #: src/natcap/invest/urban_nature_access.py:169 +#, fuzzy msgid "" -"Contributions to an urban nature pixel decrease exponentially, where " -"\"weight = e^(-pixel_dist / search_radius)\"" +"Contributions to an urban nature pixel decrease exponentially, where \"weight = " +"e^(-pixel_dist / search_radius)\"" msgstr "" +"Las contribuciones a un píxel de naturaleza urbana disminuyen exponencialmente, " +"donde \"peso = e^(-distancia_píxel / radio_de_búsqueda)\"" #: src/natcap/invest/urban_nature_access.py:176 msgid "" "Contributions to an urban nature pixel decrease according to a normal " "(\"gaussian\") distribution with a sigma of 3." msgstr "" +"Las contribuciones a un píxel de naturaleza urbana disminuyen según una " +"distribución normal (\"gaussiana\") con un sigma de 3." #: src/natcap/invest/urban_nature_access.py:183 +#, fuzzy msgid "" -"Contributions to an urban nature pixel decrease faster as distances " -"approach the search radius. Weights are calculated by \"weight = 0.75 * " -"(1-(pixel_dist / search_radius)^2)\"" +"Contributions to an urban nature pixel decrease faster as distances approach the " +"search radius. Weights are calculated by \"weight = 0.75 * (1-(pixel_dist / " +"search_radius)^2)\"" msgstr "" +"Las contribuciones a un píxel de naturaleza urbana disminuyen más rápidamente a " +"medida que las distancias se acercan al radio de búsqueda. Las ponderaciones se " +"calculan mediante \"peso = 0,75 * (1-(distancia_píxel / radio_de_búsqueda)^2)\"" #: src/natcap/invest/urban_nature_access.py:210 #, fuzzy msgid "The type of search radius to use." -msgstr "El tipo de valor AME en esta fila." +msgstr "El tipo de radio de búsqueda a utilizar." #: src/natcap/invest/urban_nature_access.py:216 msgid "The search radius is the same for all types of urban nature." msgstr "" +"El radio de búsqueda es el mismo para todos los tipos de naturaleza urbana." #: src/natcap/invest/urban_nature_access.py:222 msgid "" -"The search radius is defined for each distinct urban nature LULC " -"classification." +"The search radius is defined for each distinct urban nature LULC classification." msgstr "" +"El radio de búsqueda se define para cada clasificación LULC de naturaleza urbana." #: src/natcap/invest/urban_nature_access.py:228 msgid "The search radius is defined for each distinct population group." -msgstr "" +msgstr "El radio de búsqueda se define para cada grupo de población distinto." #: src/natcap/invest/urban_nature_access.py:238 msgid "" -"Whether to aggregate statistics by population group within each " -"administrative unit. If selected, population groups will be read from the" -" fields of the user-defined administrative boundaries vector. This option" -" is implied if the search radii are defined by population groups." +"Whether to aggregate statistics by population group within each administrative " +"unit. If selected, population groups will be read from the fields of the user-" +"defined administrative boundaries vector. This option is implied if the search " +"radii are defined by population groups." msgstr "" +"Si se desea agregar estadísticas por grupo de población dentro de cada unidad " +"administrativa. Si se selecciona, los grupos de población se leerán de los " +"campos del vector de límites administrativos definidos por el usuario. Esta " +"opción está implícita si los radios de búsqueda están definidos por grupos de " +"población." #: src/natcap/invest/urban_nature_access.py:252 msgid "" -"The search radius to use when running the model under a uniform search " -"radius. Required when running the model with a uniform search radius. " -"Units are in meters." +"The search radius to use when running the model under a uniform search radius. " +"Required when running the model with a uniform search radius. Units are in " +"meters." msgstr "" +"El radio de búsqueda a utilizar cuando se ejecuta el modelo con un radio de " +"búsqueda uniforme. Requerido cuando se ejecuta el modelo con un radio de " +"búsqueda uniforme. Las unidades están en metros." #: src/natcap/invest/urban_nature_access.py:266 msgid "" -"The name of the population group. Names must match the names defined in " -"the administrative boundaries vector." +"The name of the population group. Names must match the names defined in the " +"administrative boundaries vector." msgstr "" +"Nombre del grupo de población. Los nombres deben coincidir con los definidos en " +"el vector de límites administrativos." #: src/natcap/invest/urban_nature_access.py:276 msgid "" -"The search radius in meters to use for this population group. Values " -"must be >= 0." +"The search radius in meters to use for this population group. Values must be >= " +"0." msgstr "" +"El radio de búsqueda en metros a utilizar para este grupo de población. Los " +"valores deben ser >= 0." #: src/natcap/invest/urban_nature_access.py:282 msgid "" -"A table associating population groups with the distance in meters that " -"members of the population group will, on average, travel to find urban " -"nature. Required when running the model with search radii defined per " -"population group." +"A table associating population groups with the distance in meters that members " +"of the population group will, on average, travel to find urban nature. Required " +"when running the model with search radii defined per population group." msgstr "" +"Una tabla que asocia grupos de población con la distancia en metros que los " +"miembros del grupo de población recorrerán, por término medio, para encontrar " +"naturaleza urbana. Necesaria cuando se ejecuta el modelo con radios de búsqueda " +"definidos por grupo de población." #: src/natcap/invest/urban_nature_access.py:418 msgid "" -"Positive pixel values indicate an oversupply of urban nature for the " -"population group POP_GROUP relative to the stated urban nature demand. " -"Negative values indicate an undersupply of urban nature for the " -"population group POP_GROUP relative to the stated urban nature demand." +"Positive pixel values indicate an oversupply of urban nature for the population " +"group POP_GROUP relative to the stated urban nature demand. Negative values " +"indicate an undersupply of urban nature for the population group POP_GROUP " +"relative to the stated urban nature demand." msgstr "" +"Los valores positivos de píxeles indican un exceso de oferta de naturaleza " +"urbana para el grupo de población POP_GROUP en relación con la demanda declarada " +"de naturaleza urbana. Los valores negativos indican una oferta insuficiente de " +"naturaleza urbana para el grupo de población POP_GROUP en relación con la " +"demanda declarada de naturaleza urbana." #: src/natcap/invest/urban_nature_access.py:432 msgid "" -"The area of greenspace available within the defined radius, weighted by " -"the selected decay function." +"The area of greenspace available within the defined radius, weighted by the " +"selected decay function." msgstr "" +"La superficie de espacio verde disponible dentro del radio definido, ponderada " +"por la función de decaimiento seleccionada." #: src/natcap/invest/urban_nature_access.py:442 msgid "" -"The area of greenspace available within the radius associated with urban " -"nature class LUCODE, weighted by the selected decay function." +"The area of greenspace available within the radius associated with urban nature " +"class LUCODE, weighted by the selected decay function." msgstr "" +"La superficie de espacio verde disponible dentro del radio asociado a la clase " +"de naturaleza urbana LUCODE, ponderada por la función de decaimiento " +"seleccionada." #: src/natcap/invest/urban_nature_access.py:453 msgid "" "The area of greenspace available within the radius associated with group " "POP_GROUP, weighted by the selected decay function." msgstr "" +"La superficie de espacio verde disponible dentro del radio asociado al grupo " +"POP_GROUP, ponderada por la función de decaimiento seleccionada." #: src/natcap/invest/urban_nature_access.py:467 msgid "" -"A copy of the user's land use land cover raster. If the user-supplied " -"LULC has non-square pixels, they will be resampled to square pixels in " -"this raster." +"A copy of the user's land use land cover raster. If the user-supplied LULC has " +"non-square pixels, they will be resampled to square pixels in this raster." msgstr "" +"Una copia del ráster de ocupación del suelo del usuario. Si el LULC suministrado " +"por el usuario tiene píxeles no cuadrados, se remuestrearán a píxeles cuadrados " +"en este ráster." #: src/natcap/invest/urban_nature_access.py:475 msgid "" -"The user's population raster, aligned to the same resolution and " -"dimensions as the aligned LULC." +"The user's population raster, aligned to the same resolution and dimensions as " +"the aligned LULC." msgstr "" +"El raster de población del usuario, alineado con las mismas resolución y " +"dimensiones que el LULC alineado." #: src/natcap/invest/urban_nature_access.py:481 msgid "The population experiencing an urban nature deficit." -msgstr "" +msgstr "La población que experimenta un déficit de naturaleza urbana." #: src/natcap/invest/urban_nature_access.py:487 msgid "The population experiencing an urban nature surplus." -msgstr "" +msgstr "La población que experimenta un excedente de naturaleza urbana." #: src/natcap/invest/urban_nature_access.py:495 msgid "" -"A sum of the population within the given search radius SEARCH_RADIUS, " -"weighted by the user's decay function." +"A sum of the population within the given search radius SEARCH_RADIUS, weighted " +"by the user's decay function." msgstr "" +"Suma de la población dentro del radio de búsqueda dado SEARCH_RADIUS, ponderada " +"por la función de decaimiento del usuario." #: src/natcap/invest/urban_nature_access.py:505 msgid "The area of urban nature (in square meters) represented in each pixel." msgstr "" +"La superficie de naturaleza urbana (en metros cuadrados) representada en cada " +"píxel." #: src/natcap/invest/urban_nature_access.py:514 msgid "The calculated urban nature/population ratio." -msgstr "" +msgstr "La tasa calculada de naturaleza urbana/población." #: src/natcap/invest/urban_nature_access.py:523 msgid "" -"Pixel values represent the ares of urban nature (in square meters) " -"represented in each pixel for the urban nature class represented by the " -"land use land cover code LUCODE." +"Pixel values represent the ares of urban nature (in square meters) represented " +"in each pixel for the urban nature class represented by the land use land cover " +"code LUCODE." msgstr "" +"Los valores de los píxeles representan las áreas de naturaleza urbana (en metros " +"cuadrados) representadas en cada píxel para la clase de naturaleza urbana " +"representada por el código de uso del suelo LUCODE." #: src/natcap/invest/urban_nature_access.py:533 msgid "" -"The urban nature supplied to populations due to the land use land cover " -"code LUCODE" +"The urban nature supplied to populations due to the land use land cover code " +"LUCODE" msgstr "" +"La naturaleza urbana suministrada a las poblaciones debido al código de " +"ocupación del suelo LUCODE" #: src/natcap/invest/urban_nature_access.py:541 msgid "" "The calculated urban nature/population ratio for the urban nature class " "represented by the land use land cover code LUCODE." msgstr "" +"La tasa naturaleza urbana/población calculada para la clase de naturaleza urbana " +"representada por el código de ocupación del suelo LUCODE." #: src/natcap/invest/urban_nature_access.py:552 msgid "" -"Each pixel represents the population of a pixel belonging to the " -"population in the population group POP_GROUP." +"Each pixel represents the population of a pixel belonging to the population in " +"the population group POP_GROUP." msgstr "" +"Cada píxel representa la población de un píxel perteneciente a la población del " +"grupo de población POP_GROUP." #: src/natcap/invest/urban_nature_access.py:561 msgid "" -"Each pixel represents the proportion of the total population that belongs" -" to the population group POP_GROUP." +"Each pixel represents the proportion of the total population that belongs to the " +"population group POP_GROUP." msgstr "" +"Cada píxel representa la proporción de la población total que pertenece al grupo " +"de población POP_GROUP." #: src/natcap/invest/urban_nature_access.py:570 msgid "" -"Each pixel represents the total number of people within the search radius" -" for the population group POP_GROUP, weighted by the user's selection of " -"decay function." +"Each pixel represents the total number of people within the search radius for " +"the population group POP_GROUP, weighted by the user's selection of decay " +"function." msgstr "" +"Cada píxel representa el número total de personas dentro del radio de búsqueda " +"para el grupo de población POP_GROUP, ponderado por la selección del usuario de " +"la función de decaimiento." #: src/natcap/invest/urban_nature_access.py:580 msgid "The total population, weighted by the appropriate decay function." -msgstr "" +msgstr "La población total, ponderada por la función de decaimiento adecuada." #: src/natcap/invest/urban_nature_access.py:588 msgid "The urban nature supply per capita to population group POP_GROUP." -msgstr "" +msgstr "La oferta de naturaleza urbana per cápita al grupo de población POP_GROUP." #: src/natcap/invest/urban_nature_access.py:596 msgid "" -"The population in population group POP_GROUP that are experiencing an " -"urban nature deficit." +"The population in population group POP_GROUP that are experiencing an urban " +"nature deficit." msgstr "" +"La población del grupo de población POP_GROUP que experimenta un déficit de " +"naturaleza urbana." #: src/natcap/invest/urban_nature_access.py:604 msgid "" -"The population in population group POP_GROUP that are experiencing an " -"urban nature surplus." +"The population in population group POP_GROUP that are experiencing an urban " +"nature surplus." msgstr "" +"La población del grupo de población POP_GROUP que experimenta un excedente de " +"naturaleza urbana." #: src/natcap/invest/validation.py:33 #, fuzzy @@ -3147,17 +3179,16 @@ msgstr "Esperaba el {header} \"{header_name}\" pero no lo encontró" #: src/natcap/invest/validation.py:37 #, fuzzy msgid "" -"Expected to find at least one {header} matching the pattern " -"\"{header_name}\" but found none" +"Expected to find at least one {header} matching the pattern \"{header_name}\" " +"but found none" msgstr "Esperaba el {header} \"{header_name}\" pero no lo encontró" #: src/natcap/invest/validation.py:40 msgid "" -"Expected the {header} \"{header_name}\" only once but found it {number} " -"times" +"Expected the {header} \"{header_name}\" only once but found it {number} times" msgstr "" -"Esperaba el {header} \"{header_name}\" solo una vez pero lo encontró " -"{number} veces" +"Esperaba el {header} \"{header_name}\" solo una vez pero lo encontró {number} " +"veces" #: src/natcap/invest/validation.py:43 #, fuzzy @@ -3170,8 +3201,8 @@ msgid "" "Layer must be projected in this unit: \"{unit_a}\" but found this unit: " "\"{unit_b}\"" msgstr "" -"La capa debe ser proyectada en esta unidad: \"{unit_a}\" pero se ha " -"encontrado esta unidad: \"{unit_b}\"" +"La capa debe ser proyectada en esta unidad: \"{unit_a}\" pero se ha encontrado " +"esta unidad: \"{unit_b}\"" #: src/natcap/invest/validation.py:48 msgid "An unexpected error occurred in validation" @@ -3246,9 +3277,11 @@ msgstr "El archivo espacial {filepath} no tiene proyección" #: src/natcap/invest/validation.py:65 msgid "" -"Not all of the spatial layers overlap each other. All bounding boxes must" -" intersect: {bboxes}" +"Not all of the spatial layers overlap each other. All bounding boxes must " +"intersect: {bboxes}" msgstr "" +"No todas las capas espaciales se solapan entre sí. Todas las cajas delimitadoras " +"deben intersecarse: {bboxes}" #: src/natcap/invest/validation.py:68 #, fuzzy @@ -3256,20 +3289,25 @@ msgid "You must have {permission} access to this file" msgstr "Debe tener acceso {permission} a este archivo" #: src/natcap/invest/validation.py:70 +#, fuzzy msgid "Geometry type must be one of {allowed}" -msgstr "" +msgstr "El tipo de geometría debe ser uno de los {allowed}." #: src/natcap/invest/wave_energy.py:34 +#, fuzzy msgid "Index of this percentile bin." -msgstr "" +msgstr "Índice de esta ubicación percentil." #: src/natcap/invest/wave_energy.py:38 +#, fuzzy msgid "Percentile range within this bin." -msgstr "" +msgstr "Rango de percentiles dentro de esta ubicación." #: src/natcap/invest/wave_energy.py:42 +#, fuzzy msgid "Number of pixels whose wave energy values fall into this percentile bin." msgstr "" +"Número de píxeles cuyos valores de energía de onda caen dentro de este percentil." #: src/natcap/invest/wave_energy.py:51 src/natcap/invest/wind_energy.py:331 msgid "Unique identifier for each point." @@ -3334,8 +3372,7 @@ msgstr "Vector de extracción para el Mar del Norte con una resolución de 4 met #: src/natcap/invest/wave_energy.py:197 msgid "WaveWatchIII data for the North Sea 4 meter resolution." msgstr "" -"Datos de WaveWatchIII para el Mar del Norte con una resolución de 4 " -"metros." +"Datos de WaveWatchIII para el Mar del Norte con una resolución de 4 metros." #: src/natcap/invest/wave_energy.py:204 msgid "Point vector for the North Sea 10 meter resolution." @@ -3344,14 +3381,12 @@ msgstr "Vector de puntos para el Mar del Norte con una resolución de 10 metros. #: src/natcap/invest/wave_energy.py:210 msgid "Extract vector for the North Sea 10 meter resolution." msgstr "" -"Vector de extracción para el Mar del Norte con una resolución de 10 " -"metros." +"Vector de extracción para el Mar del Norte con una resolución de 10 metros." #: src/natcap/invest/wave_energy.py:214 msgid "WaveWatchIII data for the North Sea 10 meter resolution." msgstr "" -"Datos de WaveWatchIII para el Mar del Norte con una resolución de 10 " -"metros." +"Datos de WaveWatchIII para el Mar del Norte con una resolución de 10 metros." #: src/natcap/invest/wave_energy.py:221 msgid "Point vector for Australia." @@ -3379,11 +3414,10 @@ msgstr "Datos de Global WaveWatchIII." #: src/natcap/invest/wave_energy.py:244 msgid "" -"Pre-packaged wave energy data directory. This is provided with the sample" -" data." +"Pre-packaged wave energy data directory. This is provided with the sample data." msgstr "" -"Directorio de datos de energía de las olas preempaquetado. Se proporciona" -" con los datos de muestra." +"Directorio de datos de energía de las olas preempaquetado. Se proporciona con " +"los datos de muestra." #: src/natcap/invest/wave_energy.py:247 msgid "wave base data" @@ -3423,25 +3457,24 @@ msgstr "área de análisis" #: src/natcap/invest/wave_energy.py:275 msgid "" -"A matrix of the wave machine performance, or ability to capture wave " -"energy, in different sea state conditions. The first column contains wave" -" height values (in meters, increasing from top to bottom), and the first " -"row contains wave period values (in seconds, increasing from left to " -"right). Values within the matrix are the machine performance in kilowatts" -" at that sea state condition, described by the wave height (row) and wave" -" period (column). The model linearly interpolates sea state data from the" -" base wave dataset onto this matrix to determine performance." -msgstr "" -"Una matriz del rendimiento de la máquina de olas, o de la capacidad de " -"captar la energía de las olas, en diferentes condiciones del estado del " -"mar. La primera columna contiene los valores de la altura de las olas (en" -" metros, aumentando de arriba hacia abajo), y la primera fila contiene " -"los valores del periodo de las olas (en segundos, aumentando de izquierda" -" a derecha). Los valores dentro de la matriz son el rendimiento de la " -"máquina en kilovatios en esa condición de estado del mar, descrita por la" -" altura de la ola (fila) y el período de la ola (columna). El modelo " -"interpola linealmente los datos del estado del mar del conjunto de datos " -"de olas base en esta matriz para determinar el rendimiento." +"A matrix of the wave machine performance, or ability to capture wave energy, in " +"different sea state conditions. The first column contains wave height values (in " +"meters, increasing from top to bottom), and the first row contains wave period " +"values (in seconds, increasing from left to right). Values within the matrix are " +"the machine performance in kilowatts at that sea state condition, described by " +"the wave height (row) and wave period (column). The model linearly interpolates " +"sea state data from the base wave dataset onto this matrix to determine " +"performance." +msgstr "" +"Una matriz del rendimiento de la máquina de olas, o de la capacidad de captar la " +"energía de las olas, en diferentes condiciones del estado del mar. La primera " +"columna contiene los valores de la altura de las olas (en metros, aumentando de " +"arriba hacia abajo), y la primera fila contiene los valores del periodo de las " +"olas (en segundos, aumentando de izquierda a derecha). Los valores dentro de la " +"matriz son el rendimiento de la máquina en kilovatios en esa condición de estado " +"del mar, descrita por la altura de la ola (fila) y el período de la ola " +"(columna). El modelo interpola linealmente los datos del estado del mar del " +"conjunto de datos de olas base en esta matriz para determinar el rendimiento." #: src/natcap/invest/wave_energy.py:286 msgid "machine performance table" @@ -3449,16 +3482,20 @@ msgstr "tabla de rendimiento de la máquina" #: src/natcap/invest/wave_energy.py:295 msgid "" -"Name of the machine parameter. Expected parameters are: 'capmax' (maximum" -" capacity for device, in kilowatts), 'hsmax' (upper limit of wave height " -"for device operation, in meters), and 'tpmax' (upper limit of wave period" -" for device operation, in seconds)." +"Name of the machine parameter. Expected parameters are: 'capmax' (maximum " +"capacity for device, in kilowatts), 'hsmax' (upper limit of wave height for " +"device operation, in meters), and 'tpmax' (upper limit of wave period for device " +"operation, in seconds)." msgstr "" +"Nombre del parámetro de la máquina. Los parámetros esperados son: " +"'capmax' (capacidad máxima del dispositivo, en kilovatios), 'hsmax' (límite " +"superior de la altura de ola para el funcionamiento del dispositivo, en metros) " +"y 'tpmax' (límite superior del periodo de ola para el funcionamiento del " +"dispositivo, en segundos)." #: src/natcap/invest/wave_energy.py:305 src/natcap/invest/wave_energy.py:354 -#, fuzzy msgid "Value of the machine parameter." -msgstr "tabla de parámetros de la máquina" +msgstr "Tabla de parámetros de la máquina." #: src/natcap/invest/wave_energy.py:308 msgid "Table of parameters for the wave energy machine in use." @@ -3489,35 +3526,42 @@ msgstr "ejecutar validación" #: src/natcap/invest/wave_energy.py:327 msgid "" -"A table of data for each connection point. Required if Run Valuation is " -"selected." +"A table of data for each connection point. Required if Run Valuation is selected." msgstr "" -"Una tabla de datos para cada punto de conexión. Se requiere si se " -"selecciona la opción de ejecución de la validación." +"Una tabla de datos para cada punto de conexión. Se requiere si se selecciona la " +"opción de ejecución de la validación." #: src/natcap/invest/wave_energy.py:330 msgid "grid connection points table" msgstr "tabla de puntos de conexión a la cuadrícula" #: src/natcap/invest/wave_energy.py:339 +#, fuzzy msgid "" -"Name of the machine parameter. Expected parameters are: 'capmax' (maximum" -" capacity for device, in kilowatts), 'cc' (capital cost per device " -"installed, $/kilowatt), 'cml' (cost of mooring lines, $/kilometer), 'cul'" -" (cost of underwater cable, $/kilometer), 'col' (cost of overland " -"transmission lines, $/kilometer), 'omc' (operating and maintenance cost, " -"$/kilowatt hour), 'p' (price of electricity, $/kilowatt hour), 'r' " -"(discount rate, between 0 and 1), 'smlpm' (number of slack lines required" -" per machine)" -msgstr "" +"Name of the machine parameter. Expected parameters are: 'capmax' (maximum " +"capacity for device, in kilowatts), 'cc' (capital cost per device installed, $/" +"kilowatt), 'cml' (cost of mooring lines, $/kilometer), 'cul' (cost of underwater " +"cable, $/kilometer), 'col' (cost of overland transmission lines, $/kilometer), " +"'omc' (operating and maintenance cost, $/kilowatt hour), 'p' (price of " +"electricity, $/kilowatt hour), 'r' (discount rate, between 0 and 1), " +"'smlpm' (number of slack lines required per machine)" +msgstr "" +"Nombre del parámetro de la máquina. Los parámetros esperados son: " +"'capmax' (capacidad máxima del dispositivo, en kilovatios), 'cc' (costo de " +"capital por dispositivo instalado, $/kilovatio), 'cml' (costo de las líneas de " +"amarre, $/kilómetro), 'cul' (costo del cable submarino, $/kilómetro), " +"'col' (costo de las líneas de transmisión terrestre, $/kilómetro), " +"\"omc\" (costo de explotación y mantenimiento, $/kilovatio hora), \"p\" (precio " +"de la electricidad, $/kilovatio hora), \"r\" (tasa de descuento, entre 0 y 1), " +"\"smlpm\" (número de líneas de holgura necesarias por máquina)." #: src/natcap/invest/wave_energy.py:358 msgid "" -"Table of economic parameters for the wave energy machine. Required if Run" -" Valuation is selected." +"Table of economic parameters for the wave energy machine. Required if Run " +"Valuation is selected." msgstr "" -"Tabla de parámetros económicos de la máquina de energía de las olas. Se " -"requiere si se selecciona la opción de ejecución de la valoración." +"Tabla de parámetros económicos de la máquina de energía de las olas. Se requiere " +"si se selecciona la opción de ejecución de la valoración." #: src/natcap/invest/wave_energy.py:361 msgid "machine economic table" @@ -3526,8 +3570,8 @@ msgstr "cuadro económico de la máquina" #: src/natcap/invest/wave_energy.py:368 msgid "Number of wave machines to model. Required if Run Valuation is selected." msgstr "" -"Número de máquinas de olas a modelizar. Es necesario si se selecciona la " -"opción de ejecución de la validación." +"Número de máquinas de olas a modelizar. Es necesario si se selecciona la opción " +"de ejecución de la validación." #: src/natcap/invest/wave_energy.py:371 msgid "number of machines" @@ -3535,74 +3579,89 @@ msgstr "número de máquinas" #: src/natcap/invest/wave_energy.py:379 msgid "Map of captured wave energy per WEC device." -msgstr "" +msgstr "Mapa de energía de las olas captada por dispositivo WEC." #: src/natcap/invest/wave_energy.py:387 msgid "" -"Map of captured wave energy per WEC device reclassified by quantiles (1 =" -" < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +"Map of captured wave energy per WEC device reclassified by quantiles (1 = < 25%, " +"2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." msgstr "" +"Mapa de energía de las olas capturada por dispositivo WEC reclasificado por " +"cuantiles (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." #: src/natcap/invest/wave_energy.py:394 msgid "" -"Table of value ranges for each captured wave energy quantile group as " -"well as the number of pixels for each group." +"Table of value ranges for each captured wave energy quantile group as well as " +"the number of pixels for each group." msgstr "" +"Tabla de rangos de valores para cada grupo de cuantiles de energía de las olas " +"capturados, así como el número de píxeles de cada grupo." #: src/natcap/invest/wave_energy.py:404 msgid "Range of wave energy values within this percentile bin." -msgstr "" +msgstr "Rango de valores de energía de las olas dentro de este percentil." #: src/natcap/invest/wave_energy.py:412 msgid "Vector map of the provided grid points" -msgstr "" +msgstr "Mapa vectorial de los puntos de cuadrícula proporcionados" #: src/natcap/invest/wave_energy.py:418 msgid "Vector map of the provided land points" -msgstr "" +msgstr "Mapa vectorial de los puntos de tierra proporcionados" #: src/natcap/invest/wave_energy.py:423 msgid "" -"Map of positive values of net present value over the 25-year lifespan of " -"a wave energy facility, reclassified by quantiles (1 = < 25%, 2 = 25-50%," -" 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +"Map of positive values of net present value over the 25-year lifespan of a wave " +"energy facility, reclassified by quantiles (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 " +"= 75-90%, 5 = > 90%)." msgstr "" +"Mapa de valores positivos del valor actual neto durante los 25 años de vida útil " +"de una instalación de energía de olas, reclasificados por cuantiles (1 = < 25%, " +"2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." #: src/natcap/invest/wave_energy.py:431 msgid "" -"Table of value ranges for each net present value quantile group as well " -"as the number of pixels for each group." +"Table of value ranges for each net present value quantile group as well as the " +"number of pixels for each group." msgstr "" +"Tabla de rangos de valores para cada grupo de cuantiles de valor actual neto, " +"así como el número de píxeles de cada grupo." #: src/natcap/invest/wave_energy.py:441 msgid "Range of net present values within this percentile bin." -msgstr "" +msgstr "Rango de valores actuales netos dentro de este percentil." #: src/natcap/invest/wave_energy.py:448 msgid "" -"Map of net present value over the 25-year lifespan of a wave energy " -"facility." +"Map of net present value over the 25-year lifespan of a wave energy facility." msgstr "" +"Mapa del valor actual neto a lo largo de los 25 años de vida útil de una " +"instalación de energía de olas." #: src/natcap/invest/wave_energy.py:457 msgid "Map of potential wave power." -msgstr "" +msgstr "Mapa de la energía potencial de las olas." #: src/natcap/invest/wave_energy.py:464 msgid "" -"Map of potential wave power classified into quantiles (1 = < 25%, 2 = " -"25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +"Map of potential wave power classified into quantiles (1 = < 25%, 2 = 25-50%, 3 " +"= 50-75%, 4 = 75-90%, 5 = > 90%)." msgstr "" +"Mapa de la potencia potencial de las olas clasificado en cuantiles (1 = < 25%, 2 " +"= 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." #: src/natcap/invest/wave_energy.py:471 msgid "" -"Table of value ranges for each wave power quantile group as well as the " -"number of pixels for each group." +"Table of value ranges for each wave power quantile group as well as the number " +"of pixels for each group." msgstr "" +"Tabla de rangos de valores para cada grupo de cuantiles de potencia de ola, así " +"como el número de píxeles de cada grupo." #: src/natcap/invest/wave_energy.py:480 msgid "Range of potential wave power values within this percentile bin." msgstr "" +"Rango de valores potenciales de potencia de las olas dentro de este percentil." #: src/natcap/invest/wind_energy.py:36 msgid "Longitude of the data point." @@ -3615,8 +3674,7 @@ msgstr "Latitud del punto de datos." #: src/natcap/invest/wind_energy.py:46 src/natcap/invest/wind_energy.py:76 msgid "Weibull scale factor at the reference hub height at this point." msgstr "" -"Factor de escala de Weibull en la altura del buje de referencia en este " -"punto." +"Factor de escala de Weibull en la altura del buje de referencia en este punto." #: src/natcap/invest/wind_energy.py:53 msgid "Weibull shape factor at this point." @@ -3625,18 +3683,17 @@ msgstr "Factor de forma de Weibull en este punto." #: src/natcap/invest/wind_energy.py:58 #, fuzzy msgid "" -"The reference hub height at this point, at which wind speed data was " -"collected and LAM was estimated." +"The reference hub height at this point, at which wind speed data was collected " +"and LAM was estimated." msgstr "" -"La altura del buje de referencia en este punto, en el que se recogieron " -"los datos de la velocidad del viento y se estimó el LAM." +"La altura del buje de referencia en este punto, en el que se recogieron los " +"datos de la velocidad del viento y se estimó el LAM." #: src/natcap/invest/wind_energy.py:69 #, fuzzy msgid "Weibull scale factor calculated for the proposed hub height at this point." msgstr "" -"Factor de escala de Weibull en la altura del buje de referencia en este " -"punto." +"Factor de escala de Weibull en la altura del buje de referencia en este punto." #: src/natcap/invest/wind_energy.py:83 #, fuzzy @@ -3645,7 +3702,7 @@ msgstr "Factor de forma de Weibull en este punto." #: src/natcap/invest/wind_energy.py:88 msgid "Predicted energy harvested from a wind farm centered on this point." -msgstr "" +msgstr "Energía prevista cosechada de un parque eólico centrado en este punto." #: src/natcap/invest/wind_energy.py:110 msgid "Table of Weibull parameters for each wind data point." @@ -3658,22 +3715,21 @@ msgstr "puntos de datos del viento" #: src/natcap/invest/wind_energy.py:118 msgid "" "Map of the area(s) of interest over which to run the model and aggregate " -"valuation results. Required if Run Valuation is selected and the Grid " -"Connection Points table is provided." +"valuation results. Required if Run Valuation is selected and the Grid Connection " +"Points table is provided." msgstr "" -"Mapa de la(s) zona(s) de interés sobre la(s) cual(es) se ejecuta el " -"modelo y se agregan los resultados de la valoración. Se requiere si se " -"selecciona la opción de ejecutar valoración y se proporciona la tabla de " -"Puntos de conexión a la cuadrícula." +"Mapa de la(s) zona(s) de interés sobre la(s) cual(es) se ejecuta el modelo y se " +"agregan los resultados de la valoración. Se requiere si se selecciona la opción " +"de ejecutar valoración y se proporciona la tabla de Puntos de conexión a la " +"cuadrícula." #: src/natcap/invest/wind_energy.py:135 msgid "" -"Map of the coastlines of landmasses in the area of interest. Required if " -"the Minimum Distance and Maximum Distance inputs are provided." +"Map of the coastlines of landmasses in the area of interest. Required if the " +"Minimum Distance and Maximum Distance inputs are provided." msgstr "" -"Mapa de las líneas de costa de las masas de tierra en el área de interés." -" Se requiere si se proporcionan los inputs de Distancia mínima y " -"Distancia máxima." +"Mapa de las líneas de costa de las masas de tierra en el área de interés. Se " +"requiere si se proporcionan los inputs de Distancia mínima y Distancia máxima." #: src/natcap/invest/wind_energy.py:139 msgid "land polygon" @@ -3689,11 +3745,11 @@ msgstr "Exponente a utilizar en la función de la curva de potencia." #: src/natcap/invest/wind_energy.py:154 msgid "" -"Cost to decommission a turbine as a proportion of the total upfront costs" -" (cables, foundations, installation?)" +"Cost to decommission a turbine as a proportion of the total upfront costs " +"(cables, foundations, installation?)" msgstr "" -"Costo de desmantelamiento de una turbina en proporción a los costos " -"iniciales totales (cables, cimientos, instalación...)" +"Costo de desmantelamiento de una turbina en proporción a los costos iniciales " +"totales (cables, cimientos, instalación...)" #: src/natcap/invest/wind_energy.py:161 msgid "The operations and maintenance costs as a proportion of capex_arr" @@ -3733,13 +3789,13 @@ msgstr "Costo del cable de corriente continua que aumenta con la longitud." #: src/natcap/invest/wind_energy.py:201 msgid "" -"The threshold above which a wind farm’s distance from the grid requires a" -" switch from AC to DC power to overcome line losses which reduce the " -"amount of energy delivered" +"The threshold above which a wind farm’s distance from the grid requires a switch " +"from AC to DC power to overcome line losses which reduce the amount of energy " +"delivered" msgstr "" -"El umbral a partir del cual la distancia de un parque eólico a la red " -"requiere un cambio de CA a CC para superar las pérdidas de la línea que " -"reducen la cantidad de energía suministrada" +"El umbral a partir del cual la distancia de un parque eólico a la red requiere " +"un cambio de CA a CC para superar las pérdidas de la línea que reducen la " +"cantidad de energía suministrada" #: src/natcap/invest/wind_energy.py:209 msgid "The expected lifetime of the facility" @@ -3747,8 +3803,8 @@ msgstr "La vida útil prevista de la instalación" #: src/natcap/invest/wind_energy.py:213 msgid "" -"Factor that translates carbon-free wind power to a corresponding amount " -"of avoided CO2 emissions" +"Factor that translates carbon-free wind power to a corresponding amount of " +"avoided CO2 emissions" msgstr "" "Factor que traduce la energía eólica libre de carbono en una cantidad " "correspondiente de emisiones de CO2 evitadas" @@ -3759,12 +3815,11 @@ msgstr "La reducción de la densidad del aire por metro sobre el nivel del mar" #: src/natcap/invest/wind_energy.py:224 msgid "" -"The fraction of energy lost due to downtime, power conversion " -"inefficiency, and electrical grid losses" +"The fraction of energy lost due to downtime, power conversion inefficiency, and " +"electrical grid losses" msgstr "" "La fracción de energía que se pierde debido al tiempo de inactividad, la " -"ineficiencia de la conversión de energía y las pérdidas de la red " -"eléctrica" +"ineficiencia de la conversión de energía y las pérdidas de la red eléctrica" #: src/natcap/invest/wind_energy.py:228 msgid "A table of wind energy infrastructure parameters." @@ -3785,16 +3840,14 @@ msgstr "Velocidad del viento a la que la turbina empieza a producir energía." #: src/natcap/invest/wind_energy.py:248 msgid "Minimum wind speed at which the turbine reaches its rated power output." msgstr "" -"Velocidad mínima del viento a la que la turbina alcanza su potencia " -"nominal." +"Velocidad mínima del viento a la que la turbina alcanza su potencia nominal." #: src/natcap/invest/wind_energy.py:254 msgid "" -"Wind speed above which the turbine stops generating power for safety " -"reasons." +"Wind speed above which the turbine stops generating power for safety reasons." msgstr "" -"Velocidad del viento por encima de la cual la turbina deja de generar " -"energía por razones de seguridad." +"Velocidad del viento por encima de la cual la turbina deja de generar energía " +"por razones de seguridad." #: src/natcap/invest/wind_energy.py:260 msgid "The turbine's rated power output." @@ -3838,12 +3891,11 @@ msgstr "profundidad máxima" #: src/natcap/invest/wind_energy.py:292 msgid "" -"Minimum distance from shore for offshore wind farm installation. Required" -" if Run Valuation is selected." +"Minimum distance from shore for offshore wind farm installation. Required if Run " +"Valuation is selected." msgstr "" -"Distancia mínima desde la costa para la instalación de un parque eólico " -"marino. Se necesita si se selecciona la opción de ejecución de " -"valoración." +"Distancia mínima desde la costa para la instalación de un parque eólico marino. " +"Se necesita si se selecciona la opción de ejecución de valoración." #: src/natcap/invest/wind_energy.py:295 msgid "minimum distance" @@ -3851,12 +3903,11 @@ msgstr "distancia mínima" #: src/natcap/invest/wind_energy.py:301 msgid "" -"Maximum distance from shore for offshore wind farm installation. Required" -" if Run Valuation is selected." +"Maximum distance from shore for offshore wind farm installation. Required if Run " +"Valuation is selected." msgstr "" -"Distancia máxima desde la costa para la instalación del parque eólico " -"marino. Se necesita si se selecciona la opción de ejecución de " -"evaluación." +"Distancia máxima desde la costa para la instalación del parque eólico marino. Se " +"necesita si se selecciona la opción de ejecución de evaluación." #: src/natcap/invest/wind_energy.py:304 msgid "maximum distance" @@ -3885,13 +3936,12 @@ msgstr "tasa de descuento" #: src/natcap/invest/wind_energy.py:354 msgid "" -"Table of grid and land connection points to which cables will connect. " -"Required if Run Valuation is selected and Average Shore-to-Grid Distance " -"is not provided." +"Table of grid and land connection points to which cables will connect. Required " +"if Run Valuation is selected and Average Shore-to-Grid Distance is not provided." msgstr "" -"Tabla de puntos de conexión a la red y a tierra a los que se conectarán " -"los cables. Necesario si se selecciona la opción de valoración de la " -"ejecución y no se proporciona la distancia media de la orilla a la red." +"Tabla de puntos de conexión a la red y a tierra a los que se conectarán los " +"cables. Necesario si se selecciona la opción de valoración de la ejecución y no " +"se proporciona la distancia media de la orilla a la red." #: src/natcap/invest/wind_energy.py:358 msgid "grid connection points" @@ -3900,13 +3950,13 @@ msgstr "puntos de conexión a la cuadrícula" #: src/natcap/invest/wind_energy.py:365 #, fuzzy msgid "" -"Average distance to the onshore grid from coastal cable landing points. " -"Required if Run Valuation is selected and the Grid Connection Points " -"table is not provided." +"Average distance to the onshore grid from coastal cable landing points. Required " +"if Run Valuation is selected and the Grid Connection Points table is not " +"provided." msgstr "" -"Distancia media a la red terrestre desde los puntos de desembarco del " -"cable costero. Necesario si se selecciona la opción de valoración de la " -"ejecución y no se proporciona la tabla de Puntos de conexión a la red." +"Distancia media a la red terrestre desde los puntos de desembarco del cable " +"costero. Necesario si se selecciona la opción de valoración de la ejecución y no " +"se proporciona la tabla de Puntos de conexión a la red." #: src/natcap/invest/wind_energy.py:369 msgid "average shore-to-grid distance" @@ -3914,12 +3964,12 @@ msgstr "distancia media entre la costa y la red" #: src/natcap/invest/wind_energy.py:374 msgid "" -"Use a Wind Energy Price Table instead of calculating annual prices from " -"the initial Energy Price and Rate of Price Change inputs." +"Use a Wind Energy Price Table instead of calculating annual prices from the " +"initial Energy Price and Rate of Price Change inputs." msgstr "" -"Utilizar una tabla de precios de la energía eólica en lugar de calcular " -"los precios anuales a partir de los inputs iniciales del precio de la " -"energía y la tasa de variación del precio." +"Utilizar una tabla de precios de la energía eólica en lugar de calcular los " +"precios anuales a partir de los inputs iniciales del precio de la energía y la " +"tasa de variación del precio." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:362 #: src/natcap/invest/wind_energy.py:378 @@ -3928,13 +3978,13 @@ msgstr "utilizar la tabla de precios" #: src/natcap/invest/wind_energy.py:387 msgid "" -"Consecutive years for each year in the lifespan of the wind farm. These " -"may be the actual years: 2010, 2011, 2012..., or the number of the years " -"after the starting date: 1, 2, 3,..." +"Consecutive years for each year in the lifespan of the wind farm. These may be " +"the actual years: 2010, 2011, 2012..., or the number of the years after the " +"starting date: 1, 2, 3,..." msgstr "" -"Años consecutivos para cada año de la vida útil del parque eólico. Pueden" -" ser los años reales: 2010, 2011, 2012..., o el número de los años " -"posteriores a la fecha de inicio: 1, 2, 3,..." +"Años consecutivos para cada año de la vida útil del parque eólico. Pueden ser " +"los años reales: 2010, 2011, 2012..., o el número de los años posteriores a la " +"fecha de inicio: 1, 2, 3,..." #: src/natcap/invest/wind_energy.py:396 msgid "Price of energy for each year." @@ -3942,16 +3992,14 @@ msgstr "Precio de la energía para cada año." #: src/natcap/invest/wind_energy.py:400 msgid "" -"Table of yearly prices for wind energy. There must be a row for each year" -" in the lifespan given in the 'time_period' column in the Global Wind " -"Energy Parameters table. Required if Run Valuation and Use Price Table " -"are selected." +"Table of yearly prices for wind energy. There must be a row for each year in the " +"lifespan given in the 'time_period' column in the Global Wind Energy Parameters " +"table. Required if Run Valuation and Use Price Table are selected." msgstr "" -"Tabla de precios anuales de la energía eólica. Debe haber una fila por " -"cada año de la vida útil indicada en la columna \"time_period\" de la " -"tabla Global Wind Energy Parameters. Se requiere si se seleccionan las " -"opciones de valoración de la ejecución y la de utilización de la Tabla de" -" precios." +"Tabla de precios anuales de la energía eólica. Debe haber una fila por cada año " +"de la vida útil indicada en la columna \"time_period\" de la tabla Global Wind " +"Energy Parameters. Se requiere si se seleccionan las opciones de valoración de " +"la ejecución y la de utilización de la Tabla de precios." #: src/natcap/invest/wind_energy.py:405 msgid "wind energy price table" @@ -3960,13 +4008,13 @@ msgstr "tabla de precios de la energía eólica" #: src/natcap/invest/wind_energy.py:411 #, fuzzy msgid "" -"The initial price of wind energy, at the first year in the wind energy " -"farm lifespan. Required if Run Valuation is selected and Use Price Table " -"is not selected." +"The initial price of wind energy, at the first year in the wind energy farm " +"lifespan. Required if Run Valuation is selected and Use Price Table is not " +"selected." msgstr "" -"El precio inicial de la energía eólica, en el primer año de la vida útil " -"del parque eólico. Requerido si se seleccionan las opciones de valoración" -" de ejecución y no se selecciona la de utilizar Tabla de precios." +"El precio inicial de la energía eólica, en el primer año de la vida útil del " +"parque eólico. Requerido si se seleccionan las opciones de valoración de " +"ejecución y no se selecciona la de utilizar Tabla de precios." #: src/natcap/invest/wind_energy.py:415 msgid "price of energy" @@ -3975,12 +4023,12 @@ msgstr "precio de la energía" #: src/natcap/invest/wind_energy.py:420 #, fuzzy msgid "" -"The annual rate of change in the price of wind energy. Required if Run " -"Valuation is selected and Use Price Table is not selected." +"The annual rate of change in the price of wind energy. Required if Run Valuation " +"is selected and Use Price Table is not selected." msgstr "" -"La tasa de variación anual del precio de la energía eólica. Requerido si " -"se selecciona la opción de ejecución de valoración y no se selecciona la " -"de utilización de la Tabla de precios." +"La tasa de variación anual del precio de la energía eólica. Requerido si se " +"selecciona la opción de ejecución de valoración y no se selecciona la de " +"utilización de la Tabla de precios." #: src/natcap/invest/wind_energy.py:424 msgid "rate of price change" @@ -3989,37 +4037,39 @@ msgstr "tasa de variación de los precios" #: src/natcap/invest/wind_energy.py:432 msgid "Map of offset carbon emissions for a farm centered on each pixel" msgstr "" +"Mapa de emisiones de carbono compensadas de un parque centrado en cada píxel" #: src/natcap/invest/wind_energy.py:441 msgid "Map of power density." -msgstr "" +msgstr "Mapa de densidad de potencia." #: src/natcap/invest/wind_energy.py:448 msgid "Map of energy harvested from a farm centered on each pixel." -msgstr "" +msgstr "Mapa de la energía cosechada en un parque centrado en cada píxel." #: src/natcap/invest/wind_energy.py:456 msgid "" -"Map of the energy price that would be required to set the present value " -"of a farm centered on each pixel equal to zero." +"Map of the energy price that would be required to set the present value of a " +"farm centered on each pixel equal to zero." msgstr "" +"Mapa del precio de la energía que sería necesario para que el valor actual de un " +"parque centrada en cada píxel fuera igual a cero." #: src/natcap/invest/wind_energy.py:466 msgid "Map of the net present value of a farm centered on each pixel." -msgstr "" +msgstr "Mapa del valor actual neto de un parque centrado en cada píxel." #: src/natcap/invest/wind_energy.py:471 msgid "Map of summarized data at each point." -msgstr "" +msgstr "Mapa de datos resumidos en cada punto." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:116 #, fuzzy msgid "" -"Analysis year {analysis_year} must be >= the latest snapshot year " -"({latest_year})" +"Analysis year {analysis_year} must be >= the latest snapshot year ({latest_year})" msgstr "" -"El año de análisis {analysis_year} debe ser >= el último año de la " -"instantánea ({latest_year})" +"El año de análisis {analysis_year} debe ser >= el último año de la instantánea " +"({latest_year})" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:119 #, fuzzy @@ -4027,28 +4077,30 @@ msgid "Raster for snapshot {snapshot_year} could not be validated." msgstr "No se ha podido validar la trama de la instantánea {snapshot_year}." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:121 +#, fuzzy msgid "" -"The transition table expects values of {model_transitions} but found " -"values of {transition_values}." +"The transition table expects values of {model_transitions} but found values of " +"{transition_values}." msgstr "" +"La tabla de transiciones espera valores de {model_transitions} pero ha " +"encontrado valores de {transition_values}." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:177 msgid "" -"The snapshot year that this row's LULC raster represents. Each year in " -"this table must be unique." +"The snapshot year that this row's LULC raster represents. Each year in this " +"table must be unique." msgstr "" -"El año de la instantánea que representa el ráster LULC de esta fila. Cada" -" año de esta tabla debe ser único." +"El año de la instantánea que representa el ráster LULC de esta fila. Cada año de " +"esta tabla debe ser único." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:184 msgid "" -"Map of LULC in the given snapshot year. All values in this raster must " -"have corresponding entries in the Biophysical Table and Landcover " -"Transitions Table." +"Map of LULC in the given snapshot year. All values in this raster must have " +"corresponding entries in the Biophysical Table and Landcover Transitions Table." msgstr "" -"Mapa de LULC en el año de la instantánea. Todos los valores de este " -"ráster deben tener los inputs correspondientes en la Tabla Biofísica y en" -" la Tabla de Transiciones de la Cubierta Terrestre." +"Mapa de LULC en el año de la instantánea. Todos los valores de este ráster deben " +"tener los inputs correspondientes en la Tabla Biofísica y en la Tabla de " +"Transiciones de la Cubierta Terrestre." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:191 msgid "A table mapping snapshot years to corresponding LULC maps." @@ -4066,50 +4118,46 @@ msgstr "año de análisis" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:200 msgid "" -"A year that may be used to extend the analysis beyond the last snapshot " -"year. If used, the model assumes that carbon will continue to accumulate " -"or emit after the last snapshot year until the analysis year. This value " -"must be greater than the final snapshot year." +"A year that may be used to extend the analysis beyond the last snapshot year. If " +"used, the model assumes that carbon will continue to accumulate or emit after " +"the last snapshot year until the analysis year. This value must be greater than " +"the final snapshot year." msgstr "" -"Un año que puede utilizarse para ampliar el análisis más allá del último " -"año de la instantánea. Si se utiliza, el modelo asume que el carbono " -"seguirá acumulándose o emitiéndose después del último año de la " -"instantánea hasta el año de análisis. Este valor debe ser mayor que el " -"último año de la instantánea." +"Un año que puede utilizarse para ampliar el análisis más allá del último año de " +"la instantánea. Si se utiliza, el modelo asume que el carbono seguirá " +"acumulándose o emitiéndose después del último año de la instantánea hasta el año " +"de análisis. Este valor debe ser mayor que el último año de la instantánea." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:214 -msgid "" -"The LULC code that represents this LULC class in the LULC snapshot " -"rasters." +msgid "The LULC code that represents this LULC class in the LULC snapshot rasters." msgstr "" -"El código LULC que representa esta clase LULC en los rastreos de " -"instantáneas LULC." +"El código LULC que representa esta clase LULC en los rastreos de instantáneas " +"LULC." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:219 msgid "" -"Name of the LULC class. This label must be unique among the all the LULC " -"classes." +"Name of the LULC class. This label must be unique among the all the LULC classes." msgstr "" -"Nombre de la clase LULC. Esta etiqueta debe ser única entre todas las " -"clases LULC." +"Nombre de la clase LULC. Esta etiqueta debe ser única entre todas las clases " +"LULC." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:225 msgid "The initial carbon stocks in the biomass pool for this LULC class." msgstr "" -"Las existencias iniciales de carbono en la reserva de biomasa para esta " -"clase de LULC." +"Las existencias iniciales de carbono en la reserva de biomasa para esta clase de " +"LULC." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:231 msgid "The initial carbon stocks in the soil pool for this LULC class." msgstr "" -"Las existencias iniciales de carbono en la reserva del suelo para esta " -"clase de LULC." +"Las existencias iniciales de carbono en la reserva del suelo para esta clase de " +"LULC." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:237 msgid "The initial carbon stocks in the litter pool for this LULC class." msgstr "" -"Las existencias iniciales de carbono en la reserva de hojarasca para esta" -" clase de LULC." +"Las existencias iniciales de carbono en la reserva de hojarasca para esta clase " +"de LULC." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:244 msgid "The half-life of carbon in the biomass pool." @@ -4117,31 +4165,30 @@ msgstr "La vida media del carbono en la reserva de biomasa." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:247 msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a " -"cell transitions away from this LULC class in a low-impact disturbance." +"Proportion of carbon stock in the biomass pool that is disturbed when a cell " +"transitions away from this LULC class in a low-impact disturbance." msgstr "" "Proporción de las existencias de carbono en la reserva de biomasa que se " -"perturba cuando una celda se aleja de esta clase de LULC en una " -"perturbación de bajo impacto." +"perturba cuando una celda se aleja de esta clase de LULC en una perturbación de " +"bajo impacto." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:253 msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a " -"cell transitions away from this LULC class in a medium-impact " -"disturbance." +"Proportion of carbon stock in the biomass pool that is disturbed when a cell " +"transitions away from this LULC class in a medium-impact disturbance." msgstr "" -"Proporción de las existencias de carbono en la reserva de biomasa que se " -"ve perturbada cuando una celda se aleja de esta clase de LULC en una " -"perturbación de impacto medio." +"Proporción de las existencias de carbono en la reserva de biomasa que se ve " +"perturbada cuando una celda se aleja de esta clase de LULC en una perturbación " +"de impacto medio." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:259 msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a " -"cell transitions away from this LULC class in a high-impact disturbance." +"Proportion of carbon stock in the biomass pool that is disturbed when a cell " +"transitions away from this LULC class in a high-impact disturbance." msgstr "" "Proporción de las existencias de carbono en la reserva de biomasa que se " -"perturba cuando una celda se aleja de esta clase de LULC en una " -"perturbación de alto impacto." +"perturba cuando una celda se aleja de esta clase de LULC en una perturbación de " +"alto impacto." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:266 msgid "Annual rate of CO2E accumulation in the biomass pool." @@ -4153,30 +4200,30 @@ msgstr "La vida media del carbono en la reserva del suelo." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:275 msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell" -" transitions away from this LULC class in a low-impact disturbance." +"Proportion of carbon stock in the soil pool that is disturbed when a cell " +"transitions away from this LULC class in a low-impact disturbance." msgstr "" -"Proporción de las existencias de carbono en la reserva de suelo que se " -"perturba cuando una celda se aleja de esta clase de LULC en una " -"perturbación de bajo impacto." +"Proporción de las existencias de carbono en la reserva de suelo que se perturba " +"cuando una celda se aleja de esta clase de LULC en una perturbación de bajo " +"impacto." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:281 msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell" -" transitions away from this LULC class in a medium-impact disturbance." +"Proportion of carbon stock in the soil pool that is disturbed when a cell " +"transitions away from this LULC class in a medium-impact disturbance." msgstr "" -"Proporción de las existencias de carbono en la reserva de suelo que se " -"perturba cuando una celda se aleja de esta clase de LULC en una " -"perturbación de impacto medio." +"Proporción de las existencias de carbono en la reserva de suelo que se perturba " +"cuando una celda se aleja de esta clase de LULC en una perturbación de impacto " +"medio." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:287 msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell" -" transitions away from this LULC class in a high-impact disturbance." +"Proportion of carbon stock in the soil pool that is disturbed when a cell " +"transitions away from this LULC class in a high-impact disturbance." msgstr "" -"Proporción de las existencias de carbono en la reserva de suelo que se " -"perturba cuando una célula se aleja de esta clase de LULC en una " -"perturbación de alto impacto." +"Proporción de las existencias de carbono en la reserva de suelo que se perturba " +"cuando una célula se aleja de esta clase de LULC en una perturbación de alto " +"impacto." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:294 msgid "Annual rate of CO2E accumulation in the soil pool." @@ -4224,53 +4271,51 @@ msgstr "ningún cambio en el carbono" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:333 #, fuzzy msgid "" -"A transition matrix describing the type of carbon action that occurs when" -" each LULC type transitions to each other type. Values in the first " -"column, 'lulc-class', represents the original LULC class that is " -"transitioned away from. Values in the first row represents the LULC class" -" that is transitioned to. Each cell in the matrix is filled with an " -"option indicating the effect on carbon when transitioning from that " -"cell's row's LULC class to that cell's column's LULC class. The classes " -"in this table must exactly match the classes in the Biophysical Table " -"'lulc-class' column. A cell may be left empty if the transition never " -"occurs." -msgstr "" -"Una matriz de transición que describe el tipo de acción de carbono que se" -" produce cuando cada tipo de LULC hace la transición a otro tipo. Los " -"valores de la primera columna, \"lulc-class\", representan la clase LULC " -"original de la que se produce la transición. Los valores de la primera " -"fila representan la clase LULC a la que se produce la transición. Cada " -"celda de la matriz se rellena con una opción que indica el efecto sobre " -"el carbono al pasar de la clase LULC de la fila de esa celda a la clase " -"LULC de la columna de esa celda. Las clases de esta tabla deben coincidir" -" exactamente con las clases de la columna \"lulc-class\" de la tabla " -"biofísica. Una celda puede dejarse vacía si la transición no se produce " +"A transition matrix describing the type of carbon action that occurs when each " +"LULC type transitions to each other type. Values in the first column, 'lulc-" +"class', represents the original LULC class that is transitioned away from. " +"Values in the first row represents the LULC class that is transitioned to. Each " +"cell in the matrix is filled with an option indicating the effect on carbon when " +"transitioning from that cell's row's LULC class to that cell's column's LULC " +"class. The classes in this table must exactly match the classes in the " +"Biophysical Table 'lulc-class' column. A cell may be left empty if the " +"transition never occurs." +msgstr "" +"Una matriz de transición que describe el tipo de acción de carbono que se " +"produce cuando cada tipo de LULC hace la transición a otro tipo. Los valores de " +"la primera columna, \"lulc-class\", representan la clase LULC original de la que " +"se produce la transición. Los valores de la primera fila representan la clase " +"LULC a la que se produce la transición. Cada celda de la matriz se rellena con " +"una opción que indica el efecto sobre el carbono al pasar de la clase LULC de la " +"fila de esa celda a la clase LULC de la columna de esa celda. Las clases de esta " +"tabla deben coincidir exactamente con las clases de la columna \"lulc-class\" de " +"la tabla biofísica. Una celda puede dejarse vacía si la transición no se produce " "nunca." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:348 msgid "" -"A transition matrix mapping the type of carbon action undergone when one " -"LULC type transitions to another." +"A transition matrix mapping the type of carbon action undergone when one LULC " +"type transitions to another." msgstr "" -"Una matriz de transición que mapea el tipo de acción del carbono que se " -"produce cuando un tipo de LULC transiciona a otro." +"Una matriz de transición que mapea el tipo de acción del carbono que se produce " +"cuando un tipo de LULC transiciona a otro." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:356 msgid "" -"Enable net present valuation analysis based on carbon prices from either " -"a yearly price table, or an initial price and yearly interest rate." +"Enable net present valuation analysis based on carbon prices from either a " +"yearly price table, or an initial price and yearly interest rate." msgstr "" -"Permitir el análisis de la valoración actual neta basada en los precios " -"del carbono a partir de una tabla de precios anuales, o de un precio " -"inicial y un tipo de interés anual." +"Permitir el análisis de la valoración actual neta basada en los precios del " +"carbono a partir de una tabla de precios anuales, o de un precio inicial y un " +"tipo de interés anual." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:365 msgid "" -"Use a yearly price table, rather than an initial price and interest rate," -" to indicate carbon value over time." +"Use a yearly price table, rather than an initial price and interest rate, to " +"indicate carbon value over time." msgstr "" -"Utilice una tabla de precios anuales, en lugar de un precio inicial y un " -"tipo de interés, para indicar el valor del carbono a lo largo del tiempo." +"Utilice una tabla de precios anuales, en lugar de un precio inicial y un tipo de " +"interés, para indicar el valor del carbono a lo largo del tiempo." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:370 msgid "price" @@ -4279,25 +4324,24 @@ msgstr "precio" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:374 #, fuzzy msgid "" -"The price of CO2E at the baseline year. Required if Do Valuation is " -"selected and Use Price Table is not selected." +"The price of CO2E at the baseline year. Required if Do Valuation is selected and " +"Use Price Table is not selected." msgstr "" -"El precio del CO2E en el año de referencia. Es necesario si se selecciona" -" la opción de ejecución de valoración y no se selecciona la de utilizar " -"la Tabla de precios." +"El precio del CO2E en el año de referencia. Es necesario si se selecciona la " +"opción de ejecución de valoración y no se selecciona la de utilizar la Tabla de " +"precios." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:379 msgid "interest rate" -msgstr "tipo de interés" +msgstr "tasa de interés" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:382 msgid "" -"Annual increase in the price of CO2E. Required if Do Valuation is " -"selected and Use Price Table is not selected." +"Annual increase in the price of CO2E. Required if Do Valuation is selected and " +"Use Price Table is not selected." msgstr "" -"Incremento anual del precio del CO2E. Es necesario si se selecciona la " -"opción de hacer valoración y no se selecciona la de utilizar la Tabla de " -"precios." +"Incremento anual del precio del CO2E. Es necesario si se selecciona la opción de " +"hacer valoración y no se selecciona la de utilizar la Tabla de precios." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:387 msgid "price table" @@ -4314,23 +4358,23 @@ msgstr "Precio del CO2E en ese año." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:402 #, fuzzy msgid "" -"Table of annual CO2E prices for each year from the baseline year to the " -"final snapshot or analysis year. Required if Do Valuation is selected and" -" Use Price Table is selected." +"Table of annual CO2E prices for each year from the baseline year to the final " +"snapshot or analysis year. Required if Do Valuation is selected and Use Price " +"Table is selected." msgstr "" -"Tabla de precios anuales de CO2E para cada año desde el año de referencia" -" hasta la instantánea final o el año de análisis. Se requiere si se " -"selecciona las opciones de ejecutar valoración y usar Tabla de precios." +"Tabla de precios anuales de CO2E para cada año desde el año de referencia hasta " +"la instantánea final o el año de análisis. Se requiere si se selecciona las " +"opciones de ejecutar valoración y usar Tabla de precios." #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:411 #, fuzzy msgid "" -"Annual discount rate on the price of carbon. This is compounded each year" -" after the baseline year. Required if Run Valuation is selected." +"Annual discount rate on the price of carbon. This is compounded each year after " +"the baseline year. Required if Run Valuation is selected." msgstr "" -"Tasa de descuento anual sobre el precio del carbono. Se compone cada año " -"después del año de referencia. Se requiere si se selecciona la Valoración" -" de la Ejecución." +"Tasa de descuento anual sobre el precio del carbono. Se compone cada año después " +"del año de referencia. Se requiere si se selecciona la Valoración de la " +"Ejecución." #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:33 msgid "LULC lookup table" @@ -4338,21 +4382,20 @@ msgstr "Tabla de consulta LULC" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:35 msgid "" -"A table mapping LULC codes from the snapshot rasters to the corresponding" -" LULC class names, and whether or not the class is a coastal blue carbon " -"habitat." +"A table mapping LULC codes from the snapshot rasters to the corresponding LULC " +"class names, and whether or not the class is a coastal blue carbon habitat." msgstr "" -"Una tabla que mapea los códigos LULC de los rásters de las instantáneas " -"con los nombres de las clases LULC correspondientes, y si la clase es o " -"no un hábitat costero de carbono azul." +"Una tabla que mapea los códigos LULC de los rásters de las instantáneas con los " +"nombres de las clases LULC correspondientes, y si la clase es o no un hábitat " +"costero de carbono azul." #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:43 msgid "" -"LULC code. Every value in the snapshot LULC maps must have a " -"corresponding entry in this column." +"LULC code. Every value in the snapshot LULC maps must have a corresponding entry " +"in this column." msgstr "" -"Código LULC. Cada valor de los mapas LULC de la instantánea debe tener un" -" input correspondiente en esta columna." +"Código LULC. Cada valor de los mapas LULC de la instantánea debe tener un input " +"correspondiente en esta columna." #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:49 msgid "Name of the LULC class." @@ -4361,11 +4404,10 @@ msgstr "Nombre de la clase LULC." #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:52 #, fuzzy msgid "" -"Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if " -"not." +"Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if not." msgstr "" -"Introduzca TRUE si esta clase LULC es un hábitat costero de carbono azul," -" FALSE si no." +"Introduzca TRUE si esta clase LULC es un hábitat costero de carbono azul, FALSE " +"si no." #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:63 msgid "Year to snapshot." @@ -4376,8 +4418,8 @@ msgid "" "Map of LULC in the snapshot year. All values in this raster must have " "corresponding entries in the LULC Lookup table." msgstr "" -"Mapa de LULC en el año de la instantánea. Todos los valores de este " -"ráster deben tener los inputs correspondientes en la tabla LULC Lookup." +"Mapa de LULC en el año de la instantánea. Todos los valores de este ráster deben " +"tener los inputs correspondientes en la tabla LULC Lookup." #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:73 msgid "A table mapping snapshot years to corresponding LULC maps for each year." @@ -4395,19 +4437,21 @@ msgstr "Códigos LULC que coinciden con los códigos de la tabla biofísica." #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:100 msgid "" -"Carbon disturbance occurred. Replace this with one of ‘low-impact-" -"disturb’, ‘med-impact-disturb’, or ‘high-impact-disturb’ to indicate the " -"degree of disturbance." +"Carbon disturbance occurred. Replace this with one of ‘low-impact-disturb’, ‘med-" +"impact-disturb’, or ‘high-impact-disturb’ to indicate the degree of disturbance." msgstr "" +"Se ha producido una alteración del carbono. Sustitúyalo por ‘low-impact-" +"disturb’, ‘med-impact-disturb’, o ‘high-impact-disturb’ para indicar el grado de " +"perturbación." #: src/natcap/invest/delineateit/delineateit.py:46 msgid "" -"Detect pour points (watershed outlets) based on the DEM, and use these " -"instead of a user-provided outlet features vector." +"Detect pour points (watershed outlets) based on the DEM, and use these instead " +"of a user-provided outlet features vector." msgstr "" -"Detectar los puntos de vertido (salidas de la cuenca) basándose en el " -"MDE, y utilizarlos en lugar de un vector de características de salida " -"proporcionado por la persona usuaria." +"Detectar los puntos de vertido (salidas de la cuenca) basándose en el MDE, y " +"utilizarlos en lugar de un vector de características de salida proporcionado por " +"la persona usuaria." #: src/natcap/invest/delineateit/delineateit.py:50 msgid "detect pour points" @@ -4416,12 +4460,11 @@ msgstr "detección de puntos de vertido" #: src/natcap/invest/delineateit/delineateit.py:57 #, fuzzy msgid "" -"A map of watershed outlets from which to delineate the watersheds. " -"Required if Detect Pour Points is not checked." +"A map of watershed outlets from which to delineate the watersheds. Required if " +"Detect Pour Points is not checked." msgstr "" "Un mapa de puntos de vertido a partir del cual delinear las cuencas " -"hidrográficas. Se requiere si no se marca la opción Detectar puntos de " -"vertido." +"hidrográficas. Se requiere si no se marca la opción Detectar puntos de vertido." #: src/natcap/invest/delineateit/delineateit.py:60 msgid "watershed outlets" @@ -4430,18 +4473,18 @@ msgstr "puntos de salida de la cuenca" #: src/natcap/invest/delineateit/delineateit.py:65 #, fuzzy msgid "" -"Whether to snap point geometries to the nearest stream pixel. If " -"``True``, ``args['flow_threshold']`` and ``args['snap_distance']`` must " -"also be defined. If a point is equally near to more than one stream " -"pixel, it will be snapped to the stream pixel with the highest flow " -"accumulation value. This has no effect if Detect Pour Points is selected." +"Whether to snap point geometries to the nearest stream pixel. If ``True``, " +"``args['flow_threshold']`` and ``args['snap_distance']`` must also be defined. " +"If a point is equally near to more than one stream pixel, it will be snapped to " +"the stream pixel with the highest flow accumulation value. This has no effect if " +"Detect Pour Points is selected." msgstr "" -"Si se ajustan las geometrías de los puntos al píxel de flujo más cercano." -" Si es ``Verdadero``, ``args['flow_threshold']`` y " -"``args['snap_distance']`` también deben ser definidos. Si un punto está " -"igualmente cerca de más de un píxel de la corriente, se ajustará al píxel" -" de la corriente con el mayor valor de acumulación de flujo. Esto no " -"tiene efecto si se selecciona la opción Detectar puntos de vertido." +"Si se ajustan las geometrías de los puntos al píxel de flujo más cercano. Si es " +"``Verdadero``, ``args['flow_threshold']`` y ``args['snap_distance']`` también " +"deben ser definidos. Si un punto está igualmente cerca de más de un píxel de la " +"corriente, se ajustará al píxel de la corriente con el mayor valor de " +"acumulación de flujo. Esto no tiene efecto si se selecciona la opción Detectar " +"puntos de vertido." #: src/natcap/invest/delineateit/delineateit.py:73 msgid "snap points to the nearest stream" @@ -4455,12 +4498,11 @@ msgstr "sobre Requerido si se selecciona Puntos de ajuste." #: src/natcap/invest/delineateit/delineateit.py:87 #, fuzzy msgid "" -"Maximum distance to relocate watershed outlet points in order to snap " -"them to a stream. Required if Snap Points is selected." +"Maximum distance to relocate watershed outlet points in order to snap them to a " +"stream. Required if Snap Points is selected." msgstr "" -"Distancia máxima para reubicar los puntos de salida de la cuenca con el " -"fin de ajustarlos a una corriente. Se requiere si se selecciona Ajustar " -"puntos." +"Distancia máxima para reubicar los puntos de salida de la cuenca con el fin de " +"ajustarlos a una corriente. Se requiere si se selecciona Ajustar puntos." #: src/natcap/invest/delineateit/delineateit.py:91 msgid "snap distance" @@ -4469,12 +4511,12 @@ msgstr "distancia de ajuste" #: src/natcap/invest/delineateit/delineateit.py:96 #, fuzzy msgid "" -"Skip delineation for any invalid geometries found in the Outlet Features." -" Otherwise, an invalid geometry will cause the model to crash." +"Skip delineation for any invalid geometries found in the Outlet Features. " +"Otherwise, an invalid geometry will cause the model to crash." msgstr "" -"Omitir la delineación para cualquier geometría no válida encontrada en " -"las Características de salida. De lo contrario, una geometría no válida " -"hará que el modelo se bloquee." +"Omitir la delineación para cualquier geometría no válida encontrada en las " +"Características de salida. De lo contrario, una geometría no válida hará que el " +"modelo se bloquee." #: src/natcap/invest/delineateit/delineateit.py:100 msgid "skip invalid geometries" @@ -4487,22 +4529,21 @@ msgstr "O bien calc_n o bien calc_p debe ser True" #: src/natcap/invest/ndr/ndr.py:48 msgid "" -"All values in this raster must have corresponding entries in the " -"Biophysical table." +"All values in this raster must have corresponding entries in the Biophysical " +"table." msgstr "" -"Todos los valores de este ráster deben tener sus inputs correspondientes " -"en la Tabla Biofísica." +"Todos los valores de este ráster deben tener sus inputs correspondientes en la " +"Tabla Biofísica." #: src/natcap/invest/ndr/ndr.py:58 msgid "" -"Map of runoff potential, the capacity to transport nutrients downslope. " -"This can be a quickflow index or annual precipitation. Any units are " -"allowed since the values will be normalized by their average." +"Map of runoff potential, the capacity to transport nutrients downslope. This can " +"be a quickflow index or annual precipitation. Any units are allowed since the " +"values will be normalized by their average." msgstr "" -"Mapa del potencial de escorrentía, la capacidad de transportar nutrientes" -" pendiente abajo. Puede ser un índice de flujo rápido o una " -"precipitación anual. Se permite cualquier unidad ya que los valores se " -"normalizarán por su promedio." +"Mapa del potencial de escorrentía, la capacidad de transportar nutrientes " +"pendiente abajo. Puede ser un índice de flujo rápido o una precipitación anual. " +"Se permite cualquier unidad ya que los valores se normalizarán por su promedio." #: src/natcap/invest/ndr/ndr.py:63 msgid "nutrient runoff proxy" @@ -4510,11 +4551,11 @@ msgstr "proxy de escorrentía de nutrientes" #: src/natcap/invest/ndr/ndr.py:70 msgid "" -"Map of the boundaries of the watershed(s) over which to aggregate the " -"model results." +"Map of the boundaries of the watershed(s) over which to aggregate the model " +"results." msgstr "" -"Mapa de los límites de la(s) cuenca(s) sobre la(s) cual(es) se agregan " -"los resultados del modelo." +"Mapa de los límites de la(s) cuenca(s) sobre la(s) cual(es) se agregan los " +"resultados del modelo." #: src/natcap/invest/ndr/ndr.py:83 msgid "The nutrient loading for this land use class." @@ -4522,54 +4563,53 @@ msgstr "La carga de nutrientes para esta clase de uso del suelo." #: src/natcap/invest/ndr/ndr.py:87 msgid "" -"Maximum nutrient retention efficiency. This is the maximum proportion of " -"the nutrient that is retained on this LULC class." +"Maximum nutrient retention efficiency. This is the maximum proportion of the " +"nutrient that is retained on this LULC class." msgstr "" -"Eficiencia máxima de retención de nutrientes. Es la proporción máxima del" -" nutriente que se retiene en esta clase de LULC." +"Eficiencia máxima de retención de nutrientes. Es la proporción máxima del " +"nutriente que se retiene en esta clase de LULC." #: src/natcap/invest/ndr/ndr.py:94 #, fuzzy msgid "" -"The distance after which it is assumed that this LULC type retains the " -"nutrient at its maximum capacity. If nutrients travel a shorter distance " -"that this, the retention efficiency will be less than the maximum value " -"eff_x, following an exponential decay." +"The distance after which it is assumed that this LULC type retains the nutrient " +"at its maximum capacity. If nutrients travel a shorter distance that this, the " +"retention efficiency will be less than the maximum value eff_x, following an " +"exponential decay." msgstr "" -"La distancia tras la cual se supone que este tipo de LULC retiene el " -"nutriente a su máxima capacidad. Si los nutrientes recorren una distancia" -" menor que esta, la eficiencia de retención será menor que el valor " -"máximo eff_x, siguiendo un decaimiento exponencial." +"La distancia tras la cual se supone que este tipo de LULC retiene el nutriente a " +"su máxima capacidad. Si los nutrientes recorren una distancia menor que esta, la " +"eficiencia de retención será menor que el valor máximo eff_x, siguiendo un " +"decaimiento exponencial." #: src/natcap/invest/ndr/ndr.py:104 msgid "" -"The proportion of the total amount of nitrogen that are dissolved into " -"the subsurface. By default, this value should be set to 0, indicating " -"that all nutrients are delivered via surface flow. There is no equivalent" -" of this for phosphorus." +"The proportion of the total amount of nitrogen that are dissolved into the " +"subsurface. By default, this value should be set to 0, indicating that all " +"nutrients are delivered via surface flow. There is no equivalent of this for " +"phosphorus." msgstr "" -"La proporción de la cantidad total de nitrógeno que se disuelve en el " -"subsuelo. Por defecto, este valor debe fijarse en 0, lo que indica que " -"todos los nutrientes se suministran a través del flujo superficial. No " -"existe un equivalente de esto para el fósforo." +"La proporción de la cantidad total de nitrógeno que se disuelve en el subsuelo. " +"Por defecto, este valor debe fijarse en 0, lo que indica que todos los " +"nutrientes se suministran a través del flujo superficial. No existe un " +"equivalente de esto para el fósforo." #: src/natcap/invest/ndr/ndr.py:111 msgid "" "A table mapping each LULC class to its biophysical properties related to " -"nutrient load and retention. Replace '[NUTRIENT]' in the column names " -"with 'n' or 'p' for nitrogen or phosphorus respectively. Nitrogen data " -"must be provided if Calculate Nitrogen is selected. Phosphorus data must " -"be provided if Calculate Phosphorus is selected. All LULC codes in the " -"LULC raster must have corresponding entries in this table." +"nutrient load and retention. Replace '[NUTRIENT]' in the column names with 'n' " +"or 'p' for nitrogen or phosphorus respectively. Nitrogen data must be provided " +"if Calculate Nitrogen is selected. Phosphorus data must be provided if Calculate " +"Phosphorus is selected. All LULC codes in the LULC raster must have " +"corresponding entries in this table." msgstr "" "Una tabla que asigna cada clase de LULC a sus propiedades biofísicas " "relacionadas con la carga y la retención de nutrientes. Sustituya " "\"[NUTRIENTE]\" en los nombres de las columnas por \"n\" o \"p\" para el " "nitrógeno o el fósforo, respectivamente. Los datos de nitrógeno deben " -"proporcionarse si se selecciona Calcular nitrógeno. Los datos de fósforo " -"deben proporcionarse si se selecciona Calcular fósforo. Todos los códigos" -" LULC en el ráster LULC deben tener los inputs correspondientes en esta " -"tabla." +"proporcionarse si se selecciona Calcular nitrógeno. Los datos de fósforo deben " +"proporcionarse si se selecciona Calcular fósforo. Todos los códigos LULC en el " +"ráster LULC deben tener los inputs correspondientes en esta tabla." #: src/natcap/invest/ndr/ndr.py:124 msgid "Calculate phosphorus retention and export." @@ -4589,15 +4629,15 @@ msgstr "calcular el nitrógeno" #: src/natcap/invest/ndr/ndr.py:138 msgid "" -"Calibration parameter that determines the shape of the relationship " -"between hydrologic connectivity (the degree of connection from patches of" -" land to the stream) and the nutrient delivery ratio (percentage of " -"nutrient that actually reaches the stream)." +"Calibration parameter that determines the shape of the relationship between " +"hydrologic connectivity (the degree of connection from patches of land to the " +"stream) and the nutrient delivery ratio (percentage of nutrient that actually " +"reaches the stream)." msgstr "" "Parámetro de calibración que determina la forma de la relación entre la " -"conectividad hidrológica (el grado de conexión de los parches de tierra " -"con la corriente) y la proporción de suministro de nutrientes (porcentaje" -" de nutrientes que realmente llegan a la corriente)." +"conectividad hidrológica (el grado de conexión de los parches de tierra con la " +"corriente) y la proporción de suministro de nutrientes (porcentaje de nutrientes " +"que realmente llegan a la corriente)." #: src/natcap/invest/ndr/ndr.py:144 src/natcap/invest/sdr/sdr.py:112 msgid "Borselli k parameter" @@ -4610,13 +4650,13 @@ msgstr "longitud crítica en el subsuelo (nitrógeno)" #: src/natcap/invest/ndr/ndr.py:151 #, fuzzy msgid "" -"The distance traveled (subsurface and downslope) after which it is " -"assumed that soil retains nitrogen at its maximum capacity. Required if " -"Calculate Nitrogen is selected." +"The distance traveled (subsurface and downslope) after which it is assumed that " +"soil retains nitrogen at its maximum capacity. Required if Calculate Nitrogen is " +"selected." msgstr "" -"La distancia recorrida (subsuperficie y pendiente abajo) después de la " -"cual se supone que el suelo retiene el nitrógeno a su máxima capacidad. " -"Se requiere si se selecciona Calcular nitrógeno." +"La distancia recorrida (subsuperficie y pendiente abajo) después de la cual se " +"supone que el suelo retiene el nitrógeno a su máxima capacidad. Se requiere si " +"se selecciona Calcular nitrógeno." #: src/natcap/invest/ndr/ndr.py:159 msgid "subsurface maximum retention efficiency (nitrogen)" @@ -4625,14 +4665,13 @@ msgstr "eficiencia máxima de retención subsuperficial (nitrógeno)" #: src/natcap/invest/ndr/ndr.py:160 #, fuzzy msgid "" -"The maximum nitrogen retention efficiency that can be reached through " -"subsurface flow. This characterizes the retention due to biochemical " -"degradation in soils. Required if Calculate Nitrogen is selected." +"The maximum nitrogen retention efficiency that can be reached through subsurface " +"flow. This characterizes the retention due to biochemical degradation in soils. " +"Required if Calculate Nitrogen is selected." msgstr "" -"La máxima eficiencia de retención de nitrógeno que se puede alcanzar a " -"través del flujo subsuperficial. Caracteriza la retención debida a la " -"degradación bioquímica en los suelos. Se requiere si se selecciona " -"Calcular Nitrógeno." +"La máxima eficiencia de retención de nitrógeno que se puede alcanzar a través " +"del flujo subsuperficial. Caracteriza la retención debida a la degradación " +"bioquímica en los suelos. Se requiere si se selecciona Calcular Nitrógeno." #: src/natcap/invest/recreation/recmodel_client.py:51 msgid "A unique identifier for the predictor (10 characters or less)." @@ -4650,67 +4689,65 @@ msgstr "El tipo de archivo predictor proporcionado en la columna \"path\"." #: src/natcap/invest/recreation/recmodel_client.py:66 #, fuzzy msgid "" -"Predictor is a raster. Metric is the mean of values within the AOI grid " -"cell or polygon." +"Predictor is a raster. Metric is the mean of values within the AOI grid cell or " +"polygon." msgstr "" -"El predictor es un ráster. La métrica es la media de los valores dentro " -"de la celda o polígono de la cuadrícula del ADI." +"El predictor es un ráster. La métrica es la media de los valores dentro de la " +"celda o polígono de la cuadrícula del ADI." #: src/natcap/invest/recreation/recmodel_client.py:70 #, fuzzy msgid "" -"Predictor is a raster. Metric is the sum of values within the AOI grid " -"cell or polygon." +"Predictor is a raster. Metric is the sum of values within the AOI grid cell or " +"polygon." msgstr "" -"El predictor es un ráster. La métrica es la suma de los valores dentro de" -" la celda de la cuadrícula del ADI o del polígono." +"El predictor es un ráster. La métrica es la suma de los valores dentro de la " +"celda de la cuadrícula del ADI o del polígono." #: src/natcap/invest/recreation/recmodel_client.py:74 #, fuzzy msgid "" -"Predictor is a point vector. Metric is the number of points within each " -"AOI grid cell or polygon." +"Predictor is a point vector. Metric is the number of points within each AOI grid " +"cell or polygon." msgstr "" -"El predictor es un vector de puntos. La métrica es el número de puntos " -"dentro de cada celda de la cuadrícula o polígono del ADI." +"El predictor es un vector de puntos. La métrica es el número de puntos dentro de " +"cada celda de la cuadrícula o polígono del ADI." #: src/natcap/invest/recreation/recmodel_client.py:78 #, fuzzy msgid "" -"Predictor is a point vector. Metric is the Euclidean distance between the" -" centroid of each AOI grid cell and the nearest point in this layer." +"Predictor is a point vector. Metric is the Euclidean distance between the " +"centroid of each AOI grid cell and the nearest point in this layer." msgstr "" -"El predictor es un vector de puntos. La métrica es la distancia " -"euclidiana entre el centro de cada celda de la cuadrícula ADI y el punto " -"más cercano de esta capa." +"El predictor es un vector de puntos. La métrica es la distancia euclidiana entre " +"el centro de cada celda de la cuadrícula ADI y el punto más cercano de esta capa." #: src/natcap/invest/recreation/recmodel_client.py:83 #, fuzzy msgid "" -"Predictor is a line vector. Metric is the total length of the lines that " -"fall within each AOI grid cell." +"Predictor is a line vector. Metric is the total length of the lines that fall " +"within each AOI grid cell." msgstr "" -"El predictor es un vector de líneas. La métrica es la longitud total de " -"las líneas que caen dentro de cada celda de la cuadrícula ADI." +"El predictor es un vector de líneas. La métrica es la longitud total de las " +"líneas que caen dentro de cada celda de la cuadrícula ADI." #: src/natcap/invest/recreation/recmodel_client.py:87 #, fuzzy msgid "" -"Predictor is a polygon vector. Metric is the area of overlap between the " -"polygon and each AOI grid cell." +"Predictor is a polygon vector. Metric is the area of overlap between the polygon " +"and each AOI grid cell." msgstr "" -"El predictor es un vector de polígonos. La métrica es el área de " -"solapamiento entre el polígono y cada celda de la cuadrícula ADI." +"El predictor es un vector de polígonos. La métrica es el área de solapamiento " +"entre el polígono y cada celda de la cuadrícula ADI." #: src/natcap/invest/recreation/recmodel_client.py:91 #, fuzzy msgid "" -"Predictor is a polygon vector. Metric is the percentage (0-100) of " -"overlapping area between the polygon and each AOI grid cell." +"Predictor is a polygon vector. Metric is the percentage (0-100) of overlapping " +"area between the polygon and each AOI grid cell." msgstr "" -"El predictor es un vector de polígonos. La métrica es el porcentaje " -"(0-100) del área de superposición entre el polígono y cada celda de la " -"cuadrícula ADI." +"El predictor es un vector de polígonos. La métrica es el porcentaje (0-100) del " +"área de superposición entre el polígono y cada celda de la cuadrícula ADI." #: src/natcap/invest/recreation/recmodel_client.py:110 msgid "Map of area(s) over which to run the model." @@ -4719,8 +4756,8 @@ msgstr "Mapa de la(s) zona(s) sobre la(s) que se va a ejecutar el modelo." #: src/natcap/invest/recreation/recmodel_client.py:115 msgid "FQDN to a recreation server. If not provided, a default is assumed." msgstr "" -"FQDN a un servidor de recreación. Si no se proporciona, se asume un " -"valor por defecto." +"FQDN a un servidor de recreación. Si no se proporciona, se asume un valor por " +"defecto." #: src/natcap/invest/recreation/recmodel_client.py:118 #, fuzzy @@ -4740,13 +4777,13 @@ msgstr "puerto" #: src/natcap/invest/recreation/recmodel_client.py:134 msgid "" -"Year at which to start photo user-day calculations. Calculations start on" -" the first day of the year. Year must be in the range 2005 - 2017, and " -"must be less than or equal to the End Year." +"Year at which to start photo user-day calculations. Calculations start on the " +"first day of the year. Year must be in the range 2005 - 2017, and must be less " +"than or equal to the End Year." msgstr "" -"Año en el que se inician los cálculos de los días de usuario de las " -"fotos. Los cálculos comienzan el primer día del año. El año debe estar en" -" el rango 2005 - 2017, y debe ser menor o igual que el año final." +"Año en el que se inician los cálculos de los días de usuario de las fotos. Los " +"cálculos comienzan el primer día del año. El año debe estar en el rango 2005 - " +"2017, y debe ser menor o igual que el año final." #: src/natcap/invest/recreation/recmodel_client.py:139 msgid "start year" @@ -4754,13 +4791,13 @@ msgstr "año de inicio" #: src/natcap/invest/recreation/recmodel_client.py:145 msgid "" -"Year at which to end photo user-day calculations. Calculations continue " -"through the last day of the year. Year must be in the range 2005 - 2017, " -"and must be greater than or equal to the Start Year." +"Year at which to end photo user-day calculations. Calculations continue through " +"the last day of the year. Year must be in the range 2005 - 2017, and must be " +"greater than or equal to the Start Year." msgstr "" -"Año en el que se terminan los cálculos de los días de uso de las fotos. " -"Los cálculos continúan hasta el último día del año. El año debe estar en " -"el rango 2005 - 2017, y debe ser mayor o igual que el año de inicio." +"Año en el que se terminan los cálculos de los días de uso de las fotos. Los " +"cálculos continúan hasta el último día del año. El año debe estar en el rango " +"2005 - 2017, y debe ser mayor o igual que el año de inicio." #: src/natcap/invest/recreation/recmodel_client.py:150 msgid "end year" @@ -4769,12 +4806,11 @@ msgstr "año final" #: src/natcap/invest/recreation/recmodel_client.py:155 #, fuzzy msgid "" -"Divide the AOI polygons into equal-sized grid cells, and compute results " -"for those cells instead of the original polygons." +"Divide the AOI polygons into equal-sized grid cells, and compute results for " +"those cells instead of the original polygons." msgstr "" -"Divida los polígonos del ADI en celdas de cuadrícula de igual tamaño y " -"calcule los resultados para esas celdas en lugar de los polígonos " -"originales." +"Divida los polígonos del ADI en celdas de cuadrícula de igual tamaño y calcule " +"los resultados para esas celdas en lugar de los polígonos originales." # Check English #: src/natcap/invest/recreation/recmodel_client.py:159 @@ -4793,11 +4829,11 @@ msgstr "hexágono" #: src/natcap/invest/recreation/recmodel_client.py:168 #, fuzzy msgid "" -"The shape of grid cells to make within the AOI polygons. Required if Grid" -" AOI is selected." +"The shape of grid cells to make within the AOI polygons. Required if Grid AOI is " +"selected." msgstr "" -"La forma de las celdas de la cuadrícula a realizar dentro de los " -"polígonos de la ADI. Se requiere si se selecciona Grilla de ADI ." +"La forma de las celdas de la cuadrícula a realizar dentro de los polígonos de la " +"ADI. Se requiere si se selecciona Grilla de ADI ." #: src/natcap/invest/recreation/recmodel_client.py:171 msgid "grid type" @@ -4806,15 +4842,14 @@ msgstr "tipo de cuadrícula" #: src/natcap/invest/recreation/recmodel_client.py:178 #, fuzzy msgid "" -"Size of grid cells to make, measured in the projection units of the AOI. " -"If the Grid Type is 'square', this is the length of each side of the " -"square. If the Grid Type is 'hexagon', this is the hexagon's maximal " -"diameter." +"Size of grid cells to make, measured in the projection units of the AOI. If the " +"Grid Type is 'square', this is the length of each side of the square. If the " +"Grid Type is 'hexagon', this is the hexagon's maximal diameter." msgstr "" -"Tamaño de las celdas de la cuadrícula a realizar, medido en las unidades " -"de proyección del ADI. Si el tipo de cuadrícula es \"cuadrado\", es la " -"longitud de cada lado del cuadrado. Si el tipo de cuadrícula es " -"\"hexágono\", es el diámetro máximo del hexágono." +"Tamaño de las celdas de la cuadrícula a realizar, medido en las unidades de " +"proyección del ADI. Si el tipo de cuadrícula es \"cuadrado\", es la longitud de " +"cada lado del cuadrado. Si el tipo de cuadrícula es \"hexágono\", es el diámetro " +"máximo del hexágono." #: src/natcap/invest/recreation/recmodel_client.py:183 msgid "cell size" @@ -4822,11 +4857,11 @@ msgstr "tamaño de la celda" #: src/natcap/invest/recreation/recmodel_client.py:188 msgid "" -"Run the regression model using the predictor table and scenario table, if" -" provided." +"Run the regression model using the predictor table and scenario table, if " +"provided." msgstr "" -"Ejecute el modelo de regresión utilizando la tabla de predictores y la " -"tabla de escenarios, si se proporciona." +"Ejecute el modelo de regresión utilizando la tabla de predictores y la tabla de " +"escenarios, si se proporciona." #: src/natcap/invest/recreation/recmodel_client.py:191 msgid "compute regression" @@ -4834,12 +4869,12 @@ msgstr "calcular la regresión" #: src/natcap/invest/recreation/recmodel_client.py:198 msgid "" -"A table that maps predictor IDs to spatial files and their predictor " -"metric types. The file paths can be absolute or relative to the table." +"A table that maps predictor IDs to spatial files and their predictor metric " +"types. The file paths can be absolute or relative to the table." msgstr "" -"Una tabla que asigna los ID de los predictores a los archivos espaciales " -"y a sus tipos de métricas de predicción. Las rutas de los archivos pueden" -" ser absolutas o relativas a la tabla." +"Una tabla que asigna los ID de los predictores a los archivos espaciales y a sus " +"tipos de métricas de predicción. Las rutas de los archivos pueden ser absolutas " +"o relativas a la tabla." #: src/natcap/invest/recreation/recmodel_client.py:202 msgid "predictor table" @@ -4847,12 +4882,12 @@ msgstr "tabla de predicción" #: src/natcap/invest/recreation/recmodel_client.py:209 msgid "" -"A table of future or alternative scenario predictors. Maps IDs to files " -"and their types. The file paths can be absolute or relative to the table." +"A table of future or alternative scenario predictors. Maps IDs to files and " +"their types. The file paths can be absolute or relative to the table." msgstr "" -"Una tabla de predictores de escenarios futuros o alternativos. Asigna los" -" ID a los archivos y sus tipos. Las rutas de los archivos pueden ser " -"absolutas o relativas a la tabla." +"Una tabla de predictores de escenarios futuros o alternativos. Asigna los ID a " +"los archivos y sus tipos. Las rutas de los archivos pueden ser absolutas o " +"relativas a la tabla." #: src/natcap/invest/recreation/recmodel_client.py:213 msgid "scenario predictor table" @@ -4860,89 +4895,96 @@ msgstr "tabla de predicción de escenarios" #: src/natcap/invest/recreation/recmodel_client.py:218 msgid "Copy of the the AOI vector with aggregate attributes added." -msgstr "" +msgstr "Copia del vector AOI con atributos agregados añadidos." #: src/natcap/invest/recreation/recmodel_client.py:223 msgid "The average photo-user-days per year" -msgstr "" +msgstr "Promedio de días-fotógrafo por año" #: src/natcap/invest/recreation/recmodel_client.py:229 msgid "The average photo-user-days for each month." -msgstr "" +msgstr "La media de días-foto de cada mes." #: src/natcap/invest/recreation/recmodel_client.py:237 msgid "Table of monthly photo-user-days." -msgstr "" +msgstr "Tabla de días-foto mensuales." #: src/natcap/invest/recreation/recmodel_client.py:242 #, fuzzy msgid "Polygon ID" -msgstr "POLYGON" +msgstr "Polygon ID" #: src/natcap/invest/recreation/recmodel_client.py:245 msgid "Total photo-user-days counted in each cell in the given month." -msgstr "" +msgstr "Total de foto-usuarios-días contabilizados en cada celda en el mes dado." #: src/natcap/invest/recreation/recmodel_client.py:255 msgid "AOI polygons with their corresponding predictor attributes." -msgstr "" +msgstr "Polígonos AOI con sus correspondientes atributos predictores." #: src/natcap/invest/recreation/recmodel_client.py:262 #: src/natcap/invest/recreation/recmodel_client.py:287 msgid "Predictor attribute value for each polygon." -msgstr "" +msgstr "Valor del atributo predictor para cada polígono." #: src/natcap/invest/recreation/recmodel_client.py:269 msgid "" -"This is a text file output of the regression analysis. It includes " -"estimates for each predictor variable. It also contains a “server id " -"hash” value which can be used to correlate the PUD result with the data " -"available on the PUD server. If these results are used in publication " -"this hash should be included with the results for reproducibility." +"This is a text file output of the regression analysis. It includes estimates for " +"each predictor variable. It also contains a “server id hash” value which can be " +"used to correlate the PUD result with the data available on the PUD server. If " +"these results are used in publication this hash should be included with the " +"results for reproducibility." msgstr "" +"Se trata de un archivo de texto resultante del análisis de regresión. Incluye " +"estimaciones para cada variable predictora. También contiene un valor \"server " +"id hash\" que puede utilizarse para correlacionar el resultado PUD con los datos " +"disponibles en el servidor PUD. Si estos resultados se utilizan en una " +"publicación, este hash debe incluirse con los resultados para su " +"reproducibilidad." #: src/natcap/invest/recreation/recmodel_client.py:279 -msgid "" -"AOI polygons with their corresponding predictor attributes in the " -"scenario." +msgid "AOI polygons with their corresponding predictor attributes in the scenario." msgstr "" +"Polígonos AOI con sus correspondientes atributos predictores en el escenario." #: src/natcap/invest/recreation/recmodel_client.py:293 +#, fuzzy msgid "The estimated PUD_YR_AVG per polygon." -msgstr "" +msgstr "El PUD_YR_AVG estimado por polígono." #: src/natcap/invest/recreation/recmodel_client.py:301 msgid "Copy of the input AOI, gridded if applicable." -msgstr "" +msgstr "Copia de la AOI de entrada, cuadriculada si procede." #: src/natcap/invest/recreation/recmodel_client.py:307 msgid "Compressed AOI" -msgstr "" +msgstr "AOU comprimido" #: src/natcap/invest/recreation/recmodel_client.py:310 msgid "aggregated predictor values within each polygon" -msgstr "" +msgstr "valores predictivos agregados dentro de cada polígono" #: src/natcap/invest/recreation/recmodel_client.py:314 #, fuzzy msgid "Predictor estimates" -msgstr "tabla de predicción" +msgstr "Estimaciones predictivas" #: src/natcap/invest/recreation/recmodel_client.py:317 msgid "Compressed photo-user-day data" -msgstr "" +msgstr "Datos foto-usuario-día comprimidos" #: src/natcap/invest/recreation/recmodel_client.py:319 +#, fuzzy msgid "Pickled dictionary mapping FIDs to shapely geometries" -msgstr "" +msgstr "Diccionario cifrado que asigna FID a geometrías con forma" #: src/natcap/invest/recreation/recmodel_client.py:326 msgid "aggregated scenario predictor values within each polygon" -msgstr "" +msgstr "valores agregados de los predictores de escenario dentro de cada polígono" #: src/natcap/invest/recreation/recmodel_client.py:333 msgid "Server version info" -msgstr "" +msgstr "Información sobre la versión del servidor" #: src/natcap/invest/scenic_quality/scenic_quality.py:66 msgid "features impacting scenic quality" @@ -4950,50 +4992,47 @@ msgstr "características que afectan a la calidad del paisaje" #: src/natcap/invest/scenic_quality/scenic_quality.py:74 msgid "" -"Maximum length of the line of sight originating from a viewpoint. The " -"value can either be positive (preferred) or negative (kept for backwards " -"compatibility), but is converted to a positive number. If this field is " -"not provided, the model will include all pixels in the DEM in the " -"visibility analysis. RADIUS preferred, but may also be called RADIUS2 for" -" backwards compatibility." -msgstr "" -"Longitud máxima de la línea de visión originada por un punto de vista. El" -" valor puede ser positivo (preferido) o negativo (se mantiene por " -"compatibilidad con versiones anteriores), pero se convierte en un número " -"positivo. Si no se proporciona este campo, el modelo incluirá todos los " -"píxeles del MDE en el análisis de visibilidad. Se prefiere RADIUS, pero " -"también puede llamarse RADIUS2 por compatibilidad con versiones " -"anteriores." +"Maximum length of the line of sight originating from a viewpoint. The value can " +"either be positive (preferred) or negative (kept for backwards compatibility), " +"but is converted to a positive number. If this field is not provided, the model " +"will include all pixels in the DEM in the visibility analysis. RADIUS preferred, " +"but may also be called RADIUS2 for backwards compatibility." +msgstr "" +"Longitud máxima de la línea de visión originada por un punto de vista. El valor " +"puede ser positivo (preferido) o negativo (se mantiene por compatibilidad con " +"versiones anteriores), pero se convierte en un número positivo. Si no se " +"proporciona este campo, el modelo incluirá todos los píxeles del MDE en el " +"análisis de visibilidad. Se prefiere RADIUS, pero también puede llamarse RADIUS2 " +"por compatibilidad con versiones anteriores." # Not sure how to translate viewshed #: src/natcap/invest/scenic_quality/scenic_quality.py:87 #, fuzzy msgid "" -"Viewshed importance coefficient. If this field is provided, the values " -"are used to weight each feature's viewshed impacts. If not provided, all " -"viewsheds are equally weighted with a weight of 1." +"Viewshed importance coefficient. If this field is provided, the values are used " +"to weight each feature's viewshed impacts. If not provided, all viewsheds are " +"equally weighted with a weight of 1." msgstr "" -"Coeficiente de importancia de la vista. Si se proporciona este campo, los" -" valores se utilizan para ponderar los impactos de las vistas de cada " -"característica. Si no se proporciona, todas las vistas se ponderan por " -"igual con un peso de 1." +"Coeficiente de importancia de la vista. Si se proporciona este campo, los " +"valores se utilizan para ponderar los impactos de las vistas de cada " +"característica. Si no se proporciona, todas las vistas se ponderan por igual con " +"un peso de 1." #: src/natcap/invest/scenic_quality/scenic_quality.py:96 msgid "" -"Viewpoint height, the elevation above the ground of each feature. If this" -" field is not provided, defaults to 0." +"Viewpoint height, the elevation above the ground of each feature. If this field " +"is not provided, defaults to 0." msgstr "" -"Altura del punto de vista, la elevación sobre el suelo de cada " -"característica. Si no se proporciona este campo, el valor predeterminado " -"es 0." +"Altura del punto de vista, la elevación sobre el suelo de cada característica. " +"Si no se proporciona este campo, el valor predeterminado es 0." #: src/natcap/invest/scenic_quality/scenic_quality.py:101 msgid "" -"Map of locations of objects that negatively affect scenic quality. This " -"must have the same projection as the DEM." +"Map of locations of objects that negatively affect scenic quality. This must " +"have the same projection as the DEM." msgstr "" -"Mapa de ubicación de los objetos que afectan negativamente a la calidad " -"del paisaje. Debe tener la misma proyección que el MDE." +"Mapa de ubicación de los objetos que afectan negativamente a la calidad del " +"paisaje. Debe tener la misma proyección que el MDE." #: src/natcap/invest/scenic_quality/scenic_quality.py:111 msgid "refractivity coefficient" @@ -5004,8 +5043,8 @@ msgid "" "The refractivity coefficient corrects for the curvature of the earth and " "refraction of visible light in air." msgstr "" -"El coeficiente de refracción corrige la curvatura de la tierra y la " -"refracción de la luz visible en el aire." +"El coeficiente de refracción corrige la curvatura de la tierra y la refracción " +"de la luz visible en el aire." #: src/natcap/invest/scenic_quality/scenic_quality.py:124 msgid "Valuation function" @@ -5025,12 +5064,12 @@ msgstr "exponencial: a * e^(-bx)" #: src/natcap/invest/scenic_quality/scenic_quality.py:133 msgid "" -"Valuation function used to calculate the visual impact of each feature, " -"given distance from the feature 'x' and parameters 'a' and 'b'." +"Valuation function used to calculate the visual impact of each feature, given " +"distance from the feature 'x' and parameters 'a' and 'b'." msgstr "" "Función de valoración utilizada para calcular el impacto visual de cada " -"característica, dada la distancia de la característica \"x\" y los " -"parámetros \"a\" y \"b\"." +"característica, dada la distancia de la característica \"x\" y los parámetros " +"\"a\" y \"b\"." #: src/natcap/invest/scenic_quality/scenic_quality.py:139 msgid "coefficient a" @@ -5054,75 +5093,93 @@ msgstr "radio máximo de valoración" #: src/natcap/invest/scenic_quality/scenic_quality.py:158 msgid "" -"Valuation will only be computed for cells that fall within this radius of" -" a feature impacting scenic quality." +"Valuation will only be computed for cells that fall within this radius of a " +"feature impacting scenic quality." msgstr "" -"La valoración solo se calculará para las celdas que se encuentren dentro " -"de este radio de un elemento que afecte a la calidad del paisaje." +"La valoración solo se calculará para las celdas que se encuentren dentro de este " +"radio de un elemento que afecte a la calidad del paisaje." #: src/natcap/invest/scenic_quality/scenic_quality.py:168 msgid "Map of visual quality classified into quartiles." -msgstr "" +msgstr "Mapa de la calidad visual clasificada en cuartiles." #: src/natcap/invest/scenic_quality/scenic_quality.py:173 msgid "" -"This raster layer contains the weighted sum of all visibility rasters. If" -" no weight column is provided in the structures point vector, this raster" -" will represent a count of the number of structure points that are " -"visible from each pixel." +"This raster layer contains the weighted sum of all visibility rasters. If no " +"weight column is provided in the structures point vector, this raster will " +"represent a count of the number of structure points that are visible from each " +"pixel." msgstr "" +"Este ráster contiene la suma ponderada de todos los rásters de visibilidad. Si " +"no se proporciona ninguna columna de peso en el vector de puntos de estructura, " +"este ráster representará un recuento del número de puntos de estructura que son " +"visibles desde cada píxel." #: src/natcap/invest/scenic_quality/scenic_quality.py:177 msgid "" -"This raster layer contains the weighted sum of the valuation rasters " -"created for each point." +"This raster layer contains the weighted sum of the valuation rasters created for " +"each point." msgstr "" +"Esta capa ráster contiene la suma ponderada de los rásters de valoración creados " +"para cada punto." #: src/natcap/invest/scenic_quality/scenic_quality.py:186 msgid "" "This vector is the AOI, reprojected to the DEM’s spatial reference and " "projection." msgstr "" +"Este vector es el AOI, reproyectado a la referencia espacial y la proyección del " +"MDE." #: src/natcap/invest/scenic_quality/scenic_quality.py:191 msgid "" -"This raster layer is a version of the DEM that has been clipped and " -"masked to the AOI and tiled. This is the DEM file that is used for the " -"viewshed analysis." +"This raster layer is a version of the DEM that has been clipped and masked to " +"the AOI and tiled. This is the DEM file that is used for the viewshed analysis." msgstr "" +"Esta capa ráster es una versión del MDE que se ha recortado y enmascarado en el " +"AOI y se ha embaldosado. Este es el archivo MDE que se utiliza para el análisis " +"de las vistas." #: src/natcap/invest/scenic_quality/scenic_quality.py:195 msgid "Copy of the structures vector, clipped to the AOI extent." -msgstr "" +msgstr "Copia del vector de estructuras, recortado a la extensión de la AOI." #: src/natcap/invest/scenic_quality/scenic_quality.py:201 msgid "" -"Copy of the structures vector, reprojected to the DEM’s spatial reference" -" and projection." +"Copy of the structures vector, reprojected to the DEM’s spatial reference and " +"projection." msgstr "" +"Copia del vector de estructuras, reproyectado a la referencia espacial y la " +"proyección del MDE." #: src/natcap/invest/scenic_quality/scenic_quality.py:206 msgid "" -"The calculated value of the viewshed amenity/disamenity given the " -"distances of pixels from the structure's viewpoint, the weight of the " -"viewpoint, the valuation function, and the a and b coefficients. The " -"viewshed’s value is only evaluated for visible pixels." +"The calculated value of the viewshed amenity/disamenity given the distances of " +"pixels from the structure's viewpoint, the weight of the viewpoint, the " +"valuation function, and the a and b coefficients. The viewshed’s value is only " +"evaluated for visible pixels." msgstr "" +"El valor calculado de la amenidad/disamenidad de la vista, dadas las distancias " +"de los píxeles desde el punto de vista de la estructura, el peso del punto de " +"vista, la función de valoración y los coeficientes a y b. El valor de la vista " +"solo se evalúa para los píxeles visibles." #: src/natcap/invest/scenic_quality/scenic_quality.py:210 msgid "" -"Map of visibility for a given structure's viewpoint. This raster has " -"pixel values of 0 (not visible), 1 (visible), or nodata (where the DEM is" -" nodata)." +"Map of visibility for a given structure's viewpoint. This raster has pixel " +"values of 0 (not visible), 1 (visible), or nodata (where the DEM is nodata)." msgstr "" +"Mapa de visibilidad para el punto de vista de una estructura determinada. Este " +"ráster tiene valores de píxel de 0 (no visible), 1 (visible) o nodata (donde el " +"DEM es nodata)." #: src/natcap/invest/sdr/sdr.py:54 msgid "" -"Map of rainfall erosivity, reflecting the intensity and duration of " -"rainfall in the area of interest." +"Map of rainfall erosivity, reflecting the intensity and duration of rainfall in " +"the area of interest." msgstr "" -"Mapa de erosividad pluvial, que refleja la intensidad y duración de las " -"lluvias en la zona de interés." +"Mapa de erosividad pluvial, que refleja la intensidad y duración de las lluvias " +"en la zona de interés." #: src/natcap/invest/sdr/sdr.py:57 msgid "erosivity" @@ -5130,11 +5187,11 @@ msgstr "erosividad" #: src/natcap/invest/sdr/sdr.py:65 msgid "" -"Map of soil erodibility, the susceptibility of soil particles to " -"detachment and transport by rainfall and runoff." +"Map of soil erodibility, the susceptibility of soil particles to detachment and " +"transport by rainfall and runoff." msgstr "" -"Mapa de erodabilidad del suelo, la susceptibilidad de las partículas del " -"suelo al desprendimiento y al transporte por la lluvia y la escorrentía." +"Mapa de erodabilidad del suelo, la susceptibilidad de las partículas del suelo " +"al desprendimiento y al transporte por la lluvia y la escorrentía." #: src/natcap/invest/sdr/sdr.py:69 msgid "soil erodibility" @@ -5142,13 +5199,13 @@ msgstr "erosionabilidad del suelo" #: src/natcap/invest/sdr/sdr.py:83 msgid "" -"Map of the boundaries of the watershed(s) over which to aggregate " -"results. Each watershed should contribute to a point of interest where " -"water quality will be analyzed." +"Map of the boundaries of the watershed(s) over which to aggregate results. Each " +"watershed should contribute to a point of interest where water quality will be " +"analyzed." msgstr "" -"Mapa de los límites de la(s) cuenca(s) sobre la(s) que se van a agregar " -"los resultados. Cada cuenca debe contribuir a un punto de interés en el " -"que se analizará la calidad del agua." +"Mapa de los límites de la(s) cuenca(s) sobre la(s) que se van a agregar los " +"resultados. Cada cuenca debe contribuir a un punto de interés en el que se " +"analizará la calidad del agua." #: src/natcap/invest/sdr/sdr.py:87 msgid "Watersheds" @@ -5164,13 +5221,12 @@ msgstr "Factor de práctica de apoyo para la USLE" #: src/natcap/invest/sdr/sdr.py:101 msgid "" -"A table mapping each LULC code to biophysical properties of that LULC " -"class. All values in the LULC raster must have corresponding entries in " -"this table." +"A table mapping each LULC code to biophysical properties of that LULC class. All " +"values in the LULC raster must have corresponding entries in this table." msgstr "" -"Una tabla que asigna cada código LULC a las propiedades biofísicas de esa" -" clase LULC. Todos los valores de la trama LULC deben tener los inputs " -"correspondientes en esta tabla." +"Una tabla que asigna cada código LULC a las propiedades biofísicas de esa clase " +"LULC. Todos los valores de la trama LULC deben tener los inputs correspondientes " +"en esta tabla." #: src/natcap/invest/sdr/sdr.py:111 msgid "Borselli k parameter." @@ -5194,11 +5250,10 @@ msgstr "Parámetro Borselli IC0" #: src/natcap/invest/sdr/sdr.py:129 msgid "" -"The maximum allowed value of the slope length parameter (L) in the LS " -"factor." +"The maximum allowed value of the slope length parameter (L) in the LS factor." msgstr "" -"El valor máximo permitido del parámetro de longitud de la pendiente (L) " -"en el factor LS." +"El valor máximo permitido del parámetro de longitud de la pendiente (L) en el " +"factor LS." #: src/natcap/invest/sdr/sdr.py:132 msgid "maximum l value" @@ -5206,13 +5261,13 @@ msgstr "valor máximo de l" #: src/natcap/invest/sdr/sdr.py:138 msgid "" -"Map of locations of artificial drainages that drain to the watershed. " -"Pixels with 1 are drainages and are treated like streams. Pixels with 0 " -"are not drainages." +"Map of locations of artificial drainages that drain to the watershed. Pixels " +"with 1 are drainages and are treated like streams. Pixels with 0 are not " +"drainages." msgstr "" -"Mapa de las ubicaciones de los drenajes artificiales que drenan a la " -"cuenca. Los píxeles con 1 son drenajes y se tratan como corrientes. Los " -"píxeles con 0 no son drenajes." +"Mapa de las ubicaciones de los drenajes artificiales que drenan a la cuenca. Los " +"píxeles con 1 son drenajes y se tratan como corrientes. Los píxeles con 0 no son " +"drenajes." #: src/natcap/invest/sdr/sdr.py:142 msgid "drainages" @@ -5221,180 +5276,215 @@ msgstr "drenajes" #: src/natcap/invest/sdr/sdr.py:229 #, fuzzy msgid "" -"CP factor derived by mapping usle_c and usle_p from the biophysical table" -" to the LULC raster." +"CP factor derived by mapping usle_c and usle_p from the biophysical table to the " +"LULC raster." msgstr "" -"Una tabla que relaciona cada código LULC del mapa LULC con los datos " -"biofísicos de esa clase LULC." +"Una tabla que relaciona cada código LULC del mapa LULC con los datos biofísicos " +"de esa clase LULC." #: src/natcap/invest/sdr/sdr.py:235 msgid "Downslope factor of the index of connectivity (Eq. (74))" -msgstr "" +msgstr "Factor de descenso de pendiente del índice de conectividad (Ec. (74))" #: src/natcap/invest/sdr/sdr.py:240 msgid "Upslope factor of the index of connectivity (Eq. (73))" -msgstr "" +msgstr "Factor de subida de la pendiente del índice de conectividad (Ec. (73))" #: src/natcap/invest/sdr/sdr.py:245 msgid "" -"Sediment downslope deposition, the amount of sediment from a given pixel " -"that does not reach a stream (Eq. (78))" +"Sediment downslope deposition, the amount of sediment from a given pixel that " +"does not reach a stream (Eq. (78))" msgstr "" +"Depósito de sedimentos pendiente abajo, la cantidad de sedimento de un píxel " +"dado que no llega a una corriente (Ec. (78))" #: src/natcap/invest/sdr/sdr.py:254 -msgid "" -"Map of sediment flux for sediment that does not reach the stream (Eq. " -"(81))" -msgstr "" +msgid "Map of sediment flux for sediment that does not reach the stream (Eq. (81))" +msgstr "Mapa de flujo de sedimentos que no llegan a la corriente (Ec. (81))" #: src/natcap/invest/sdr/sdr.py:265 msgid "Index of connectivity (Eq. (70))" -msgstr "" +msgstr "Índice de conectividad (Ec. (70))" #: src/natcap/invest/sdr/sdr.py:272 msgid "LS factor for USLE (Eq. (69))" -msgstr "" +msgstr "Factor LS para USLE (Ec. (69))" #: src/natcap/invest/sdr/sdr.py:280 msgid "" -"Flow accumulation weighted by the thresholded slope. Used in calculating " -"s_bar." +"Flow accumulation weighted by the thresholded slope. Used in calculating s_bar." msgstr "" +"Acumulación de caudal ponderada por la pendiente umbralizada. Se utiliza para " +"calcular s_bar." #: src/natcap/invest/sdr/sdr.py:289 msgid "" -"Mean thresholded slope gradient of the upslope contributing area (in eq. " -"(73))" +"Mean thresholded slope gradient of the upslope contributing area (in eq. (73))" msgstr "" +"Gradiente medio de la pendiente umbralizada de la zona contribuyente pendiente " +"arriba (en ec. (73))" #: src/natcap/invest/sdr/sdr.py:298 -#, fuzzy msgid "Sediment delivery ratio (Eq. (75))" -msgstr "Tasa de suministro de sedimentos" +msgstr "Tasa de suministro de sedimentos (Ec. (75))" #: src/natcap/invest/sdr/sdr.py:303 msgid "" -"Percent slope, thresholded to be no less than 0.005 and no greater than 1" -" (eq. (71)). 1 is equivalent to a 45 degree slope." +"Percent slope, thresholded to be no less than 0.005 and no greater than 1 (eq. " +"(71)). 1 is equivalent to a 45 degree slope." msgstr "" +"Porcentaje de pendiente, cuyo umbral no debe ser inferior a 0,005 ni superior a " +"1 (ec. (71)). 1 equivale a una pendiente de 45 grados." #: src/natcap/invest/sdr/sdr.py:310 msgid "" -"Flow accumulation weighted by the thresholded cover-management factor. " -"Used in calculating w_bar." +"Flow accumulation weighted by the thresholded cover-management factor. Used in " +"calculating w_bar." msgstr "" +"Acumulación de caudal ponderada por el factor de gestión de cobertura " +"umbralizado. Se utiliza para calcular w_bar." #: src/natcap/invest/sdr/sdr.py:319 msgid "" -"Mean thresholded cover-management factor for upslope contributing area " -"(in eq. (73))" +"Mean thresholded cover-management factor for upslope contributing area (in eq. " +"(73))" msgstr "" +"Factor de gestión de la cubierta umbralizado medio para el área contribuyente " +"pendiente arriba (en ec. (73))" #: src/natcap/invest/sdr/sdr.py:325 msgid "" -"Cover-management factor derived by mapping usle_c from the biophysical " -"table to the LULC raster." +"Cover-management factor derived by mapping usle_c from the biophysical table to " +"the LULC raster." msgstr "" +"Factor de gestión de la cubierta derivado de la correspondencia entre usle_c de " +"la tabla biofísica y el ráster LULC." #: src/natcap/invest/sdr/sdr.py:331 msgid "Cover-management factor thresholded to be no less than 0.001 (eq. (72))" msgstr "" +"Factor de gestión de la cubierta umbralizado para que sea no inferior a 0,001 " +"(ec. (72))" #: src/natcap/invest/sdr/sdr.py:337 msgid "Average aspect weighted by flow direction (in eq. (69))" -msgstr "" +msgstr "Aspecto medio ponderado por la dirección del flujo (en ec. (69))" #: src/natcap/invest/sdr/sdr.py:342 msgid "" -"Map of which pixels drain to a stream. A value of 1 means that at least " -"some of the runoff from that pixel drains to a stream in stream.tif. A " -"value of 0 means that it does not drain at all to any stream in " -"stream.tif." +"Map of which pixels drain to a stream. A value of 1 means that at least some of " +"the runoff from that pixel drains to a stream in stream.tif. A value of 0 means " +"that it does not drain at all to any stream in stream.tif." msgstr "" +"Mapa de los píxeles que drenan a una corriente. Un valor de 1 significa que al " +"menos parte de la escorrentía de ese píxel drena a una corriente en stream.tif. " +"Un valor de 0 significa que no drena en absoluto a ninguna corriente en stream." +"tif." #: src/natcap/invest/sdr/sdr.py:351 msgid "" -"Inverse of the thresholded cover-management factor times the thresholded " -"slope (in eq. (74))" +"Inverse of the thresholded cover-management factor times the thresholded slope " +"(in eq. (74))" msgstr "" +"Inverso del factor de cobertura umbralizado multiplicado por la pendiente " +"umbralizada (en la ec. (74))" #: src/natcap/invest/sdr/sdr.py:357 msgid "Copy of the input DEM, clipped to the extent of the other raster inputs." msgstr "" +"Copia del MDE de entrada, recortado en la medida de las otras entradas ráster." #: src/natcap/invest/sdr/sdr.py:366 msgid "" -"Copy of the input drainage map, clipped to the extent of the other raster" -" inputs and aligned to the DEM." +"Copy of the input drainage map, clipped to the extent of the other raster inputs " +"and aligned to the DEM." msgstr "" +"Copia del mapa de drenaje de entrada, recortado en la extensión de las otras " +"entradas ráster y alineado con el MDE." #: src/natcap/invest/sdr/sdr.py:373 msgid "" -"Copy of the input erodibility map, clipped to the extent of the other " -"raster inputs and aligned to the DEM." +"Copy of the input erodibility map, clipped to the extent of the other raster " +"inputs and aligned to the DEM." msgstr "" +"Copia del mapa de erosionabilidad de entrada, recortado a la extensión de las " +"otras entradas ráster y alineado con el MDE." #: src/natcap/invest/sdr/sdr.py:383 msgid "" -"Copy of the input erosivity map, clipped to the extent of the other " -"raster inputs and aligned to the DEM." +"Copy of the input erosivity map, clipped to the extent of the other raster " +"inputs and aligned to the DEM." msgstr "" +"Copia del mapa de erosividad de entrada, recortado en la extensión de las otras " +"entradas ráster y alineado con el MDE." #: src/natcap/invest/sdr/sdr.py:393 msgid "" -"Copy of the input Land Use Land Cover map, clipped to the extent of the " -"other raster inputs and aligned to the DEM." +"Copy of the input Land Use Land Cover map, clipped to the extent of the other " +"raster inputs and aligned to the DEM." msgstr "" +"Copia del mapa de ocupación del suelo de entrada, recortado en la extensión de " +"las otras entradas ráster y alineado con el MDE." #: src/natcap/invest/sdr/sdr.py:400 msgid "" -"A raster aligned to the DEM and clipped to the extent of the other raster" -" inputs. Pixel values indicate where a nodata value exists in the stack " -"of aligned rasters (pixel value of 0), or if all values in the stack of " -"rasters at this pixel location are valid." +"A raster aligned to the DEM and clipped to the extent of the other raster " +"inputs. Pixel values indicate where a nodata value exists in the stack of " +"aligned rasters (pixel value of 0), or if all values in the stack of rasters at " +"this pixel location are valid." msgstr "" +"Un ráster alineado con el MDE y recortado en la medida de las otras entradas " +"ráster. Los valores de píxel indican si existe un valor nodata en la pila de " +"rásteres alineados (valor de píxel de 0), o si todos los valores de la pila de " +"rásteres en esta ubicación de píxel son válidos." #: src/natcap/invest/sdr/sdr.py:410 msgid "A copy of the aligned DEM, masked using the mask raster." -msgstr "" +msgstr "Una copia del MDE alineado, enmascarado utilizando el ráster de máscara." #: src/natcap/invest/sdr/sdr.py:418 msgid "A copy of the aligned drainage map, masked using the mask raster." msgstr "" +"Una copia del mapa de drenaje alineado, enmascarado utilizando el ráster de " +"máscara." #: src/natcap/invest/sdr/sdr.py:425 msgid "A copy of the aligned erodibility map, masked using the mask raster." msgstr "" +"Una copia del mapa de erosionabilidad alineado, enmascarado utilizando el ráster " +"de máscara." #: src/natcap/invest/sdr/sdr.py:435 msgid "A copy of the aligned erosivity map, masked using the mask raster." msgstr "" +"Una copia del mapa de erosividad alineado, enmascarado utilizando el ráster de " +"máscara." #: src/natcap/invest/sdr/sdr.py:444 msgid "" -"A copy of the aligned Land Use Land Cover map, masked using the mask " -"raster." +"A copy of the aligned Land Use Land Cover map, masked using the mask raster." msgstr "" +"Una copia del mapa de uso del suelo alineado, enmascarado utilizando el ráster " +"de máscara." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:53 msgid "" -"Twelve files, one for each month. File names must end with the month " -"number (1-12). For example, the filenames 'et0_1.tif' " -"'evapotranspiration1.tif' are both valid for the month of January." +"Twelve files, one for each month. File names must end with the month number " +"(1-12). For example, the filenames 'et0_1.tif' 'evapotranspiration1.tif' are " +"both valid for the month of January." msgstr "" -"Doce archivos, uno por cada mes. Los nombres de los archivos deben " -"terminar con el número del mes (1-12). Por ejemplo, los nombres de " -"archivo \"et0_1.tif\" \"evapotranspiración1.tif\" son válidos para el mes" -" de enero." +"Doce archivos, uno por cada mes. Los nombres de los archivos deben terminar con " +"el número del mes (1-12). Por ejemplo, los nombres de archivo \"et0_1.tif\" " +"\"evapotranspiración1.tif\" son válidos para el mes de enero." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:62 msgid "" -"Directory containing maps of reference evapotranspiration for each month." -" Only .tif files should be in this folder (no .tfw, .xml, etc files)." +"Directory containing maps of reference evapotranspiration for each month. Only ." +"tif files should be in this folder (no .tfw, .xml, etc files)." msgstr "" -"Directorio que contiene los mapas de evapotranspiración de referencia " -"para cada mes. En esta carpeta solo debe haber archivos .tif (no hay " -"archivos .tfw, .xml, etc.)." +"Directorio que contiene los mapas de evapotranspiración de referencia para cada " +"mes. En esta carpeta solo debe haber archivos .tif (no hay archivos .tfw, .xml, " +"etc.)." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:66 msgid "ET0 directory" @@ -5402,23 +5492,21 @@ msgstr "Directorio ET0" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:74 msgid "" -"Twelve files, one for each month. File names must end with the month " -"number (1-12). For example, the filenames 'precip_1.tif' and " -"'precip1.tif' are both valid names for the month of January." +"Twelve files, one for each month. File names must end with the month number " +"(1-12). For example, the filenames 'precip_1.tif' and 'precip1.tif' are both " +"valid names for the month of January." msgstr "" -"Doce archivos, uno por cada mes. Los nombres de los archivos deben " -"terminar con el número del mes (1-12). Por ejemplo, los nombres de " -"archivo 'precip_1.tif' y 'precip1.tif' son ambos válidos para el mes de " -"enero." +"Doce archivos, uno por cada mes. Los nombres de los archivos deben terminar con " +"el número del mes (1-12). Por ejemplo, los nombres de archivo 'precip_1.tif' y " +"'precip1.tif' son ambos válidos para el mes de enero." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:82 msgid "" -"Directory containing maps of monthly precipitation for each month. Only " -".tif files should be in this folder (no .tfw, .xml, etc files)." +"Directory containing maps of monthly precipitation for each month. Only .tif " +"files should be in this folder (no .tfw, .xml, etc files)." msgstr "" -"Directorio que contiene los mapas de precipitación mensual para cada mes." -" En esta carpeta solo debe haber archivos .tif (no hay archivos .tfw, " -".xml, etc.)." +"Directorio que contiene los mapas de precipitación mensual para cada mes. En " +"esta carpeta solo debe haber archivos .tif (no hay archivos .tfw, .xml, etc.)." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:86 msgid "precipitation directory" @@ -5426,51 +5514,50 @@ msgstr "directorio de precipitación" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:95 msgid "" -"All values in this raster MUST have corresponding entries in the " -"Biophysical Table." +"All values in this raster MUST have corresponding entries in the Biophysical " +"Table." msgstr "" -"Todos los valores de este ráster deben tener sus correspondientes inputs " -"en la Tabla Biofísica." +"Todos los valores de este ráster deben tener sus correspondientes inputs en la " +"Tabla Biofísica." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:116 msgid "" -"Curve number values for each combination of soil group and LULC class. " -"Replace [SOIL_GROUP] with each soil group code A, B, C, D so that there " -"is one column for each soil group. Curve number values must be greater " -"than 0." +"Curve number values for each combination of soil group and LULC class. Replace " +"[SOIL_GROUP] with each soil group code A, B, C, D so that there is one column " +"for each soil group. Curve number values must be greater than 0." msgstr "" -"Valores del número de la curva para cada combinación de grupo de suelos y" -" clase LULC. Sustituya [GRUPO_SUELO] por el código de cada grupo de suelo" -" A, B, C, D para que haya una columna para cada grupo de suelo. Los " -"valores del número de la curva deben ser mayores que 0." +"Valores del número de la curva para cada combinación de grupo de suelos y clase " +"LULC. Sustituya [GRUPO_SUELO] por el código de cada grupo de suelo A, B, C, D " +"para que haya una columna para cada grupo de suelo. Los valores del número de la " +"curva deben ser mayores que 0." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:126 msgid "" -"Crop/vegetation coefficient (Kc) values for this LULC class in each " -"month. Replace [MONTH] with the numbers 1 to 12 so that there is one " -"column for each month." +"Crop/vegetation coefficient (Kc) values for this LULC class in each month. " +"Replace [MONTH] with the numbers 1 to 12 so that there is one column for each " +"month." msgstr "" -"Valores del coeficiente de cultivo/vegetación (Kc) para esta clase LULC " -"en cada mes. Sustituya [MES] por los números del 1 al 12 para que haya " -"una columna para cada mes." +"Valores del coeficiente de cultivo/vegetación (Kc) para esta clase LULC en cada " +"mes. Sustituya [MES] por los números del 1 al 12 para que haya una columna para " +"cada mes." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:133 msgid "" -"A table mapping each LULC code to biophysical properties of the " -"corresponding LULC class. All values in the LULC raster must have " -"corresponding entries in this table." +"A table mapping each LULC code to biophysical properties of the corresponding " +"LULC class. All values in the LULC raster must have corresponding entries in " +"this table." msgstr "" -"Una tabla que asigna cada código LULC a las propiedades biofísicas de la " -"clase LULC correspondiente. Todos los valores de la trama LULC deben " -"tener los inputs correspondientes en esta tabla." +"Una tabla que asigna cada código LULC a las propiedades biofísicas de la clase " +"LULC correspondiente. Todos los valores de la trama LULC deben tener los inputs " +"correspondientes en esta tabla." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:146 msgid "" -"Values are the numbers 1-12 corresponding to each month, January (1) " -"through December (12)." +"Values are the numbers 1-12 corresponding to each month, January (1) through " +"December (12)." msgstr "" -"Los valores son los números del 1 al 12 correspondientes a cada mes, de " -"enero (1) a diciembre (12)." +"Los valores son los números del 1 al 12 correspondientes a cada mes, de enero " +"(1) a diciembre (12)." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:153 msgid "The number of rain events in that month." @@ -5479,13 +5566,12 @@ msgstr "El número de eventos de lluvia en ese mes." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:159 #, fuzzy msgid "" -"A table containing the number of rain events for each month. Required if " -"neither User-Defined Local Recharge nor User-Defined Climate Zones is " -"selected." +"A table containing the number of rain events for each month. Required if neither " +"User-Defined Local Recharge nor User-Defined Climate Zones is selected." msgstr "" -"Una tabla que contiene el número de eventos de lluvia para cada mes. Se " -"requiere si no se selecciona ni Recarga Local Definida por el Usuario ni " -"Zonas Climáticas Definidas por el Usuario." +"Una tabla que contiene el número de eventos de lluvia para cada mes. Se requiere " +"si no se selecciona ni Recarga Local Definida por el Usuario ni Zonas Climáticas " +"Definidas por el Usuario." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:163 msgid "rain events table" @@ -5493,13 +5579,12 @@ msgstr "tabla de eventos de lluvia" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:168 msgid "" -"The proportion of upslope annual available local recharge that is " -"available in each month. Required if Use Monthly Alpha Table is not " -"selected." +"The proportion of upslope annual available local recharge that is available in " +"each month. Required if Use Monthly Alpha Table is not selected." msgstr "" -"La proporción de la recarga local anual disponible pendiente arriba que " -"está disponible en cada mes. Requerido si no se selecciona la opción de " -"usar la tabla mensual Alpha." +"La proporción de la recarga local anual disponible pendiente arriba que está " +"disponible en cada mes. Requerido si no se selecciona la opción de usar la tabla " +"mensual Alpha." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:172 msgid "alpha_m parameter" @@ -5507,8 +5592,8 @@ msgstr "parámetro alpha_m" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:176 msgid "" -"The proportion of the upgradient subsidy that is available for " -"downgradient evapotranspiration." +"The proportion of the upgradient subsidy that is available for downgradient " +"evapotranspiration." msgstr "" "La proporción del subsidio ascendente que está disponible para la " "evapotranspiración descendente." @@ -5519,11 +5604,10 @@ msgstr "parámetro beta_i" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:183 msgid "" -"The proportion of pixel local recharge that is available to downgradient " -"pixels." +"The proportion of pixel local recharge that is available to downgradient pixels." msgstr "" -"La proporción de la recarga local del píxel que está disponible para los " -"píxeles pendiente abajo." +"La proporción de la recarga local del píxel que está disponible para los píxeles " +"pendiente abajo." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:186 msgid "gamma parameter" @@ -5531,12 +5615,11 @@ msgstr "parámetro gamma" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:190 msgid "" -"Use user-defined local recharge data instead of calculating local " -"recharge from the other provided data." +"Use user-defined local recharge data instead of calculating local recharge from " +"the other provided data." msgstr "" -"Utilizar los datos de recarga local definidos por quien usa el modelo en " -"lugar de calcular la recarga local a partir de los otros datos " -"proporcionados." +"Utilizar los datos de recarga local definidos por quien usa el modelo en lugar " +"de calcular la recarga local a partir de los otros datos proporcionados." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:193 msgid "user-defined recharge layer (advanced)" @@ -5544,11 +5627,10 @@ msgstr "capa de recarga definida por quien usa el modelo (avanzado)" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:203 msgid "" -"Map of local recharge data. Required if User-Defined Local Recharge is " -"selected." +"Map of local recharge data. Required if User-Defined Local Recharge is selected." msgstr "" -"Mapa de datos de recarga local. Se necesita si se selecciona la opción de" -" recarga local definida por quien usa el modelo." +"Mapa de datos de recarga local. Se necesita si se selecciona la opción de " +"recarga local definida por quien usa el modelo." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:206 msgid "local recharge" @@ -5557,8 +5639,8 @@ msgstr "recarga local" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:210 msgid "Use user-defined climate zone data in lieu of a global rain events table." msgstr "" -"Utilizar datos de zonas climáticas definidas por quien usa el modelo en " -"lugar de una tabla global de eventos de lluvia." +"Utilizar datos de zonas climáticas definidas por quien usa el modelo en lugar de " +"una tabla global de eventos de lluvia." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:213 msgid "climate zones (advanced)" @@ -5566,32 +5648,30 @@ msgstr "zonas climáticas (avanzado)" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:221 msgid "" -"Climate zone ID numbers, corresponding to the values in the Climate Zones" -" map." +"Climate zone ID numbers, corresponding to the values in the Climate Zones map." msgstr "" -"Números de identificación de la zona climática, correspondientes a los " -"valores del mapa de las zonas climáticas." +"Números de identificación de la zona climática, correspondientes a los valores " +"del mapa de las zonas climáticas." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:227 msgid "" -"The number of rain events that occur in each month in this climate zone. " -"Replace [MONTH] with the month abbreviations: jan, feb, mar, apr, may, " -"jun, jul, aug, sep, oct, nov, dec, so that there is a column for each " -"month." +"The number of rain events that occur in each month in this climate zone. Replace " +"[MONTH] with the month abbreviations: jan, feb, mar, apr, may, jun, jul, aug, " +"sep, oct, nov, dec, so that there is a column for each month." msgstr "" "El número de eventos de lluvia que se producen en cada mes en esta zona " -"climática. Sustituya [MES] por las abreviaturas de los meses: ene, feb, " -"mar, abr, may, jun, jul, ago, sep, oct, nov y dic, de modo que haya una " -"columna para cada mes." +"climática. Sustituya [MES] por las abreviaturas de los meses: ene, feb, mar, " +"abr, may, jun, jul, ago, sep, oct, nov y dic, de modo que haya una columna para " +"cada mes." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:235 #, fuzzy msgid "" -"Table of monthly precipitation events for each climate zone. Required if " -"User-Defined Climate Zones is selected." +"Table of monthly precipitation events for each climate zone. Required if User-" +"Defined Climate Zones is selected." msgstr "" -"Tabla de eventos de precipitación mensual para cada zona climática. Se " -"requiere si se selecciona Zonas Climáticas Definidas por el Usuario." +"Tabla de eventos de precipitación mensual para cada zona climática. Se requiere " +"si se selecciona Zonas Climáticas Definidas por el Usuario." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:238 msgid "climate zone table" @@ -5599,11 +5679,11 @@ msgstr "tabla de zonas climáticas" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:245 msgid "" -"Map of climate zones. All values in this raster must have corresponding " -"entries in the Climate Zone Table." +"Map of climate zones. All values in this raster must have corresponding entries " +"in the Climate Zone Table." msgstr "" -"Mapa de zonas climáticas. Todos los valores de este raster deben tener " -"los inputs correspondientes en la Tabla de Zonas Climáticas." +"Mapa de zonas climáticas. Todos los valores de este raster deben tener los " +"inputs correspondientes en la Tabla de Zonas Climáticas." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:248 msgid "climate zone map" @@ -5612,8 +5692,7 @@ msgstr "mapa de zonas climáticas" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:252 msgid "Use montly alpha values instead of a single value for the whole year." msgstr "" -"Utilizar valores alfa mensuales en lugar de un único valor para todo el " -"año." +"Utilizar valores alfa mensuales en lugar de un único valor para todo el año." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:255 msgid "use monthly alpha table (advanced)" @@ -5630,11 +5709,11 @@ msgstr "El valor alfa de ese mes." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:275 #, fuzzy msgid "" -"Table of alpha values for each month. Required if Use Monthly Alpha Table" -" is selected." +"Table of alpha values for each month. Required if Use Monthly Alpha Table is " +"selected." msgstr "" -"Tabla de valores alfa para cada mes. Es necesaria si se selecciona Usar " -"tabla de alfa mensual." +"Tabla de valores alfa para cada mes. Es necesaria si se selecciona Usar tabla de " +"alfa mensual." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:278 msgid "monthly alpha table" @@ -5642,156 +5721,179 @@ msgstr "tabla alfa mensual" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:283 msgid "" -"Map of baseflow values, the contribution of a pixel to slow release flow " -"(which is not evapotranspired before it reaches the stream)." +"Map of baseflow values, the contribution of a pixel to slow release flow (which " +"is not evapotranspired before it reaches the stream)." msgstr "" +"Mapa de valores del flujo de base, la contribución de un píxel al flujo de " +"liberación lenta (que no se evapotranspira antes de llegar a la corriente)." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:293 msgid "" -"Map of B_sum values, the flow through a pixel, contributed by all upslope" -" pixels, that is not evapotranspirated before it reaches the stream." +"Map of B_sum values, the flow through a pixel, contributed by all upslope " +"pixels, that is not evapotranspirated before it reaches the stream." msgstr "" +"Mapa de valores B_sum, el flujo que atraviesa un píxel, aportado por todos los " +"píxeles de pendiente ascendente, que no es evapotranspirado antes de llegar a la " +"corriente." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:303 -#, fuzzy msgid "Map of curve number values." -msgstr "Mapa de líneas centrales de carreteras" +msgstr "Mapa de líneas centrales de carreteras." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:310 -#, fuzzy msgid "Map of available local recharge" -msgstr "recarga local" +msgstr "Mapa de recarga local disponible" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:317 -#, fuzzy msgid "Map of local recharge values" -msgstr "recarga local" +msgstr "Mapa de valores locales de recarga" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:324 msgid "" "Map of total available water, contributed by all upslope pixels, that is " "available for evapotranspiration by this pixel." msgstr "" +"Mapa del total de agua disponible, aportada por todos los píxeles de pendiente " +"ascendente, que está disponible para evapotranspiración por este píxel." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:333 msgid "" -"Map of cumulative upstream recharge: the flow through a pixel, " -"contributed by all upslope pixels, that is available for " -"evapotranspiration to downslope pixels." +"Map of cumulative upstream recharge: the flow through a pixel, contributed by " +"all upslope pixels, that is available for evapotranspiration to downslope pixels." msgstr "" +"Mapa de recarga acumulada aguas arriba: el flujo a través de un píxel, aportado " +"por todos los píxeles de pendiente ascendente, que está disponible para la " +"evapotranspiración hacia los píxeles de pendiente descendente." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:343 +#, fuzzy msgid "Map of quickflow" -msgstr "" +msgstr "Mapa de quickflow" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:350 msgid "The total precipitation across all months on this pixel." -msgstr "" +msgstr "La precipitación total a lo largo de todos los meses en este píxel." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:357 msgid "" -"Map of the values of recharge (contribution, positive or negative), to " -"the total recharge." +"Map of the values of recharge (contribution, positive or negative), to the total " +"recharge." msgstr "" +"Mapa de los valores de recarga (contribución, positiva o negativa), a la recarga " +"total." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:366 -#, fuzzy msgid "Table of biophysical values for each watershed" -msgstr "Tabla de propiedades biofísicas para cada clase de LULC." +msgstr "Tabla de propiedades biofísicas para cada clase de LULC" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:370 msgid "Mean local recharge value within the watershed" -msgstr "" +msgstr "Valor medio de recarga local en la cuenca" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:376 msgid "Total recharge contribution, (positive or negative) within the watershed." -msgstr "" +msgstr "Contribución total de recarga, (positiva o negativa) dentro de la cuenca." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:388 -#, fuzzy msgid "Map of actual evapotranspiration" -msgstr "Mapa de valores de evapotranspiración." +msgstr "Mapa de valores de evapotranspiración" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:395 msgid "" -"Map of multiple flow direction. Values are encoded in a binary format and" -" should not be used directly." +"Map of multiple flow direction. Values are encoded in a binary format and should " +"not be used directly." msgstr "" +"Mapa de dirección de flujo múltiple. Los valores están codificados en formato " +"binario y no deben utilizarse directamente." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:401 +#, fuzzy msgid "Maps of monthly quickflow (1 = January… 12 = December)" -msgstr "" +msgstr "Mapas de flujo rápido mensual (1 = enero... 12 = diciembre)" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:409 msgid "" -"Stream network map generated from the input DEM and Threshold Flow " -"Accumulation. Values of 1 represent streams, values of 0 are non-stream " -"pixels." +"Stream network map generated from the input DEM and Threshold Flow Accumulation. " +"Values of 1 represent streams, values of 0 are non-stream pixels." msgstr "" +"Mapa de la red de corrientes generado a partir del MDE de entrada y del Umbral " +"de Acumulación de Caudales. Los valores de 1 representan corrientes, los valores " +"de 0 son píxeles no corrientes." #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:418 msgid "Map of the S_i factor derived from CN" -msgstr "" +msgstr "Mapa del factor S_i derivado de CN" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:422 msgid "Copy of LULC input, aligned and clipped to match the other spatial inputs" msgstr "" +"Copia de la entrada LULC, alineada y recortada para que coincida con las otras " +"entradas espaciales" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:427 msgid "Copy of DEM input, aligned and clipped to match the other spatial inputs" msgstr "" +"Copia de la entrada MDE, alineada y recortada para que coincida con las otras " +"entradas espaciales" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:432 msgid "Pit filled DEM" -msgstr "" +msgstr "MDE con relleno de fosas" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:436 msgid "" -"Copy of soil groups input, aligned and clipped to match the other spatial" -" inputs" +"Copy of soil groups input, aligned and clipped to match the other spatial inputs" msgstr "" +"Copia de la entrada de grupos de suelos, alineada y recortada para que coincida " +"con las otras entradas espaciales" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:443 msgid "" -"Monthly precipitation rasters, aligned and clipped to match the other " -"spatial inputs" +"Monthly precipitation rasters, aligned and clipped to match the other spatial " +"inputs" msgstr "" +"Rásteres mensuales de precipitaciones, alineados y recortados para ajustarse a " +"las demás entradas espaciales" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:447 msgid "Map of monthly rain events" -msgstr "" +msgstr "Mapa de eventos de lluvia mensuales" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:452 msgid "Monthly ET0 rasters, aligned and clipped to match the other spatial inputs" msgstr "" +"Rásteres mensuales ET0, alineados y recortados para ajustarse a las demás " +"entradas espaciales" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:456 msgid "Map of monthly KC values" -msgstr "" +msgstr "Mapa de valores mensuales de KC" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:460 msgid "" -"Copy of user-defined local recharge input, aligned and clipped to match " -"the other spatial inputs" +"Copy of user-defined local recharge input, aligned and clipped to match the " +"other spatial inputs" msgstr "" +"Copia de la entrada de recarga local definida por el usuario, alineada y " +"recortada para que coincida con las demás entradas espaciales" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:465 msgid "" -"Copy of user-defined climate zones raster, aligned and clipped to match " -"the other spatial inputs" +"Copy of user-defined climate zones raster, aligned and clipped to match the " +"other spatial inputs" msgstr "" +"Copia del ráster de las zonas climáticas definidas por el usuario, alineadas y " +"recortadas para que coincidan con las demás entradas espaciales" #~ msgid "LULC code corresponding to values in the LULC map." #~ msgstr "Código LULC correspondiente a los valores del mapa LULC." #~ msgid "" -#~ "LULC code. Every value in the LULC" -#~ " maps must have a corresponding entry" -#~ " in this column." +#~ "LULC code. Every value in the LULC maps must have a corresponding entry in " +#~ "this column." #~ msgstr "" -#~ "Código LULC. Cada valor de los " -#~ "mapas LULC debe tener su correspondiente" -#~ " input en esta columna." +#~ "Código LULC. Cada valor de los mapas LULC debe tener su correspondiente input " +#~ "en esta columna." #~ msgid "very high protection" #~ msgstr "protección muy alta" @@ -5809,36 +5911,27 @@ msgstr "" #~ msgstr "protección muy baja" #~ msgid "" -#~ "Code for this LULC class from the" -#~ " LULC map. Every value in the " -#~ "LULC raster must have a corresponding" -#~ " entry in this column." +#~ "Code for this LULC class from the LULC map. Every value in the LULC raster " +#~ "must have a corresponding entry in this column." #~ msgstr "" -#~ "Código de esta clase LULC del mapa" -#~ " LULC. Cada valor de la trama " -#~ "LULC debe tener un input correspondiente" -#~ " en esta columna." +#~ "Código de esta clase LULC del mapa LULC. Cada valor de la trama LULC debe " +#~ "tener un input correspondiente en esta columna." #~ msgid "Use the predefined GLOBIO LULC map instead of providing the LULC map." #~ msgstr "" -#~ "Utilice el mapa LULC predefinido de " -#~ "GLOBIO en lugar de proporcionar el " -#~ "mapa LULC." +#~ "Utilice el mapa LULC predefinido de GLOBIO en lugar de proporcionar el mapa " +#~ "LULC." #~ msgid "use predefined LULC" #~ msgstr "utilizar LULC predefinidos" #~ msgid "" -#~ "Each LULC code must have a " -#~ "corresponding entry in the biophysical " -#~ "table. Required if Use Predefined GLOBIO" -#~ " LULC is not selected." +#~ "Each LULC code must have a corresponding entry in the biophysical table. " +#~ "Required if Use Predefined GLOBIO LULC is not selected." #~ msgstr "" -#~ "Cada código LULC debe tener un " -#~ "input correspondiente en la tabla " -#~ "biofísica. Es obligatorio si no se " -#~ "ha seleccionado la opción de utilizar" -#~ " LULC GLOBIO predefinido." +#~ "Cada código LULC debe tener un input correspondiente en la tabla biofísica. " +#~ "Es obligatorio si no se ha seleccionado la opción de utilizar LULC GLOBIO " +#~ "predefinido." #~ msgid "LULC code from the LULC map input." #~ msgstr "Código LULC del input del mapa LULC." @@ -5847,62 +5940,44 @@ msgstr "" #~ msgstr "Código LULC GLOBIO correspondiente." #~ msgid "" -#~ "A table mapping each LULC code in" -#~ " the LULC raster input to the " -#~ "corresponding GLOBIO LULC code for the" -#~ " class. Required if Use Predefined " -#~ "GLOBIO LULC is not selected." +#~ "A table mapping each LULC code in the LULC raster input to the corresponding " +#~ "GLOBIO LULC code for the class. Required if Use Predefined GLOBIO LULC is not " +#~ "selected." #~ msgstr "" -#~ "Una tabla que mapea cada código " -#~ "LULC en el input del ráster LULC" -#~ " al correspondiente código LULC GLOBIO " -#~ "para la clase. Es necesario si no" -#~ " se selecciona la opción Usar LULC" -#~ " GLOBIO predefinida." +#~ "Una tabla que mapea cada código LULC en el input del ráster LULC al " +#~ "correspondiente código LULC GLOBIO para la clase. Es necesario si no se " +#~ "selecciona la opción Usar LULC GLOBIO predefinida." #~ msgid "LULC to GLOBIO LULC Table" #~ msgstr "Tabla LULC a LULC GLOBIO " #~ msgid "" -#~ "Maps of the location of infrastructure." -#~ " For rasters, any valid value greater" -#~ " than zero indicates the presence of" -#~ " infrastrucutre. For vectors, any " -#~ "geometries indicate the presence of " -#~ "infrastructure." +#~ "Maps of the location of infrastructure. For rasters, any valid value greater " +#~ "than zero indicates the presence of infrastrucutre. For vectors, any " +#~ "geometries indicate the presence of infrastructure." #~ msgstr "" -#~ "Mapas de la ubicación de las " -#~ "infraestructuras. Para los rásters, cualquier" -#~ " valor válido superior a cero indica" -#~ " la presencia de infraestructuras. Para " -#~ "los vectores, cualquier geometría indica " -#~ "la presencia de infraestructuras." +#~ "Mapas de la ubicación de las infraestructuras. Para los rásters, cualquier " +#~ "valor válido superior a cero indica la presencia de infraestructuras. Para " +#~ "los vectores, cualquier geometría indica la presencia de infraestructuras." #~ msgid "" -#~ "Directory containing raster and/or vector " -#~ "map(s) any forms of infrastructure to" -#~ " consider in the MSA calculation." +#~ "Directory containing raster and/or vector map(s) any forms of infrastructure " +#~ "to consider in the MSA calculation." #~ msgstr "" -#~ "Directorio que contiene mapa(s) ráster " -#~ "y/o vectorial(es) cualquier forma de " -#~ "infraestructura a considerar en el " -#~ "cálculo de la abundancia media de " -#~ "especies (AME)." +#~ "Directorio que contiene mapa(s) ráster y/o vectorial(es) cualquier forma de " +#~ "infraestructura a considerar en el cálculo de la abundancia media de especies " +#~ "(AME)." #~ msgid "infrastructure directory" #~ msgstr "directorio de infraestructuras" # Not sure about translating the selected item #~ msgid "" -#~ "Map of the proportion of each " -#~ "pixel that is pasture. Required if " -#~ "Use Predefined GLOBIO LULC is not " -#~ "selected." +#~ "Map of the proportion of each pixel that is pasture. Required if Use " +#~ "Predefined GLOBIO LULC is not selected." #~ msgstr "" -#~ "Mapa de la proporción de cada " -#~ "píxel que es pasto. Es necesario " -#~ "si no se selecciona la opción de" -#~ " usar LULC GLOBIO predefinido." +#~ "Mapa de la proporción de cada píxel que es pasto. Es necesario si no se " +#~ "selecciona la opción de usar LULC GLOBIO predefinido." #~ msgid "pasture" #~ msgstr "pasto" @@ -5912,32 +5987,21 @@ msgstr "" # Idem #~ msgid "" -#~ "Map of potential vegetation classes from" -#~ " Ramankutty and Foley (1999). Required " -#~ "if Use Predefined GLOBIO LULC is " -#~ "not selected." +#~ "Map of potential vegetation classes from Ramankutty and Foley (1999). " +#~ "Required if Use Predefined GLOBIO LULC is not selected." #~ msgstr "" -#~ "Mapa de clases de vegetación potencial" -#~ " de Ramankutty y Foley (1999). Es " -#~ "necesario si no se selecciona la " -#~ "opción de usar LULC GLOBIO predefinido." +#~ "Mapa de clases de vegetación potencial de Ramankutty y Foley (1999). Es " +#~ "necesario si no se selecciona la opción de usar LULC GLOBIO predefinido." # Idem #~ msgid "" -#~ "Areas in the Pasture map with a" -#~ " pasture proportion greater than or " -#~ "equal to this threshold are considered" -#~ " grassland or livestock grazing areas. " -#~ "Required if Use Predefined GLOBIO LULC" -#~ " is not selected." +#~ "Areas in the Pasture map with a pasture proportion greater than or equal to " +#~ "this threshold are considered grassland or livestock grazing areas. Required " +#~ "if Use Predefined GLOBIO LULC is not selected." #~ msgstr "" -#~ "Las áreas en el mapa de pastos " -#~ "con una proporción de pastos mayor " -#~ "o igual a este umbral se " -#~ "consideran áreas de pastizales o de " -#~ "pastoreo de ganado. Es obligatorio si" -#~ " no se selecciona la opción de " -#~ "utilizar LULC GLOBIO predefinido." +#~ "Las áreas en el mapa de pastos con una proporción de pastos mayor o igual a " +#~ "este umbral se consideran áreas de pastizales o de pastoreo de ganado. Es " +#~ "obligatorio si no se selecciona la opción de utilizar LULC GLOBIO predefinido." #~ msgid "pasture threshold" #~ msgstr "umbral de pastoreo" @@ -5950,152 +6014,101 @@ msgstr "" # Check English (ragmentation) #~ msgid "" -#~ "Forest ragmentation quality index threshold" -#~ " below which an area is classified" -#~ " as secondary forest. Areas with FFQI" -#~ " greater than or equal to this " -#~ "threshold are classified as primary " -#~ "forest. Required if Use Predefined " -#~ "GLOBIO LULC is not selected." +#~ "Forest ragmentation quality index threshold below which an area is classified " +#~ "as secondary forest. Areas with FFQI greater than or equal to this threshold " +#~ "are classified as primary forest. Required if Use Predefined GLOBIO LULC is " +#~ "not selected." #~ msgstr "" -#~ "Umbral del índice de calidad de " -#~ "fragmentación forestal por debajo del " -#~ "cual una zona se clasifica como " -#~ "bosque secundario. Las áreas con un " -#~ "ICFF mayor o igual a este umbral" -#~ " se clasifican como bosque primario. " -#~ "Obligatorio si no se selecciona la " -#~ "opción de utilizar LULC GLOBIO " -#~ "predefinido ." +#~ "Umbral del índice de calidad de fragmentación forestal por debajo del cual " +#~ "una zona se clasifica como bosque secundario. Las áreas con un ICFF mayor o " +#~ "igual a este umbral se clasifican como bosque primario. Obligatorio si no se " +#~ "selecciona la opción de utilizar LULC GLOBIO predefinido ." #~ msgid "primary threshold" #~ msgstr "umbral primario" #~ msgid "" -#~ "This MSA value represents infrastructure " -#~ "impacts on primary vegetation. The value" -#~ " in the 'value' column is a " -#~ "distance range in meters." +#~ "This MSA value represents infrastructure impacts on primary vegetation. The " +#~ "value in the 'value' column is a distance range in meters." #~ msgstr "" -#~ "Este valor AME representa los impactos" -#~ " de la infraestructura en la " -#~ "vegetación primaria. El valor de la " -#~ "columna \"valor\" es un rango de " -#~ "distancia en metros." +#~ "Este valor AME representa los impactos de la infraestructura en la vegetación " +#~ "primaria. El valor de la columna \"valor\" es un rango de distancia en metros." #~ msgid "" -#~ "This MSA value represents infrastructure " -#~ "impacts on non-primary vegetation. The" -#~ " value in the 'value' column is " -#~ "a distance range in meters." +#~ "This MSA value represents infrastructure impacts on non-primary vegetation. " +#~ "The value in the 'value' column is a distance range in meters." #~ msgstr "" -#~ "Este valor AME representa los impactos" -#~ " de la infraestructura en la " -#~ "vegetación no primaria. El valor de " -#~ "la columna \"valor\" es un rango " -#~ "de distancia en metros." +#~ "Este valor AME representa los impactos de la infraestructura en la vegetación " +#~ "no primaria. El valor de la columna \"valor\" es un rango de distancia en " +#~ "metros." #~ msgid "" -#~ "This MSA value represents fragmentation " -#~ "impacts. The value in the 'value' " +#~ "This MSA value represents fragmentation impacts. The value in the 'value' " #~ "column is an FFQI range." #~ msgstr "" -#~ "Este valor AME representa los impactos" -#~ " de la fragmentación. El valor de " -#~ "la columna \"valor\" es un rango " -#~ "FFQI." +#~ "Este valor AME representa los impactos de la fragmentación. El valor de la " +#~ "columna \"valor\" es un rango FFQI." #~ msgid "" -#~ "This MSA value represents land-use " -#~ "impacts. The value in the 'value' " -#~ "column is one of the GLOBIO-" -#~ "recognized LULC codes." +#~ "This MSA value represents land-use impacts. The value in the 'value' column " +#~ "is one of the GLOBIO-recognized LULC codes." #~ msgstr "" -#~ "Este valor AME representa los impactos" -#~ " del uso de la tierra. El valor" -#~ " de la columna \"valor\" es uno " -#~ "de los códigos LULC reconocidos por " -#~ "GLOBIO." +#~ "Este valor AME representa los impactos del uso de la tierra. El valor de la " +#~ "columna \"valor\" es uno de los códigos LULC reconocidos por GLOBIO." #~ msgid "" -#~ "Indicates a number or range of a" -#~ " bin. This may be a single " -#~ "number e.g. 1000, a range (two " -#~ "numbers separated by a hyphen e.g. " -#~ "1000-2000), or an upper or lower " -#~ "bound (a number preceded by > or" -#~ " < e.g. <5" +#~ "Indicates a number or range of a bin. This may be a single number e.g. 1000, " +#~ "a range (two numbers separated by a hyphen e.g. 1000-2000), or an upper or " +#~ "lower bound (a number preceded by > or < e.g. <5" #~ msgstr "" -#~ "Indica un número o un rango de " -#~ "una intevalo. Puede ser un solo " -#~ "número, por ejemplo, 1000, un rango " -#~ "(dos números separados por un guion, " -#~ "por ejemplo, 1000-2000), o un límite " -#~ "superior o inferior (un número precedido" -#~ " por > o <, por ejemplo, <5" +#~ "Indica un número o un rango de una intevalo. Puede ser un solo número, por " +#~ "ejemplo, 1000, un rango (dos números separados por un guion, por ejemplo, " +#~ "1000-2000), o un límite superior o inferior (un número precedido por > o <, " +#~ "por ejemplo, <5" #~ msgid "" -#~ "MSA value for the MSA type " -#~ "specified in the 'msa_type' column, when" -#~ " the impact value is within the " -#~ "range given in the 'value' column." +#~ "MSA value for the MSA type specified in the 'msa_type' column, when the " +#~ "impact value is within the range given in the 'value' column." #~ msgstr "" -#~ "Valor de AME para el tipo de " -#~ "especificado en la columna \"msa_type\", " -#~ "cuando el valor de impacto está " -#~ "dentro del rango dado en la " -#~ "columna \"value\"." +#~ "Valor de AME para el tipo de especificado en la columna \"msa_type\", cuando " +#~ "el valor de impacto está dentro del rango dado en la columna \"value\"." #~ msgid "" -#~ "Table that sets the MSA values for" -#~ " each impact driver and each range" -#~ " of impact values." +#~ "Table that sets the MSA values for each impact driver and each range of " +#~ "impact values." #~ msgstr "" -#~ "Tabla que establece los valores AME " -#~ "para cada motor de impacto y cada" -#~ " rango de valores de impacto." +#~ "Tabla que establece los valores AME para cada motor de impacto y cada rango " +#~ "de valores de impacto." #~ msgid "MSA Parameter Table" #~ msgstr "Tabla de parámetros AME" #~ msgid "" -#~ "Predefined GLOBIO LULC map using the " -#~ "standard GLOBIO classification scheme and " -#~ "codes. Required if Use Predefined GLOBIO" -#~ " LULC is selected." +#~ "Predefined GLOBIO LULC map using the standard GLOBIO classification scheme " +#~ "and codes. Required if Use Predefined GLOBIO LULC is selected." #~ msgstr "" -#~ "Mapa LULC predefinido de GLOBIO que " -#~ "utiliza el esquema de clasificación y" -#~ " los códigos estándar de GLOBIO. Es" -#~ " necesario si se selecciona la opción" -#~ " de usar LULC GLOBIO predefinido." +#~ "Mapa LULC predefinido de GLOBIO que utiliza el esquema de clasificación y los " +#~ "códigos estándar de GLOBIO. Es necesario si se selecciona la opción de usar " +#~ "LULC GLOBIO predefinido." #~ msgid "GLOBIO Classified Land Use" #~ msgstr "Uso del suelo clasificado por GLOBIO" #~ msgid "" -#~ "The column '{column_name}' was not found" -#~ " in the Threat Data table for " -#~ "the corresponding input LULC scenario." +#~ "The column '{column_name}' was not found in the Threat Data table for the " +#~ "corresponding input LULC scenario." #~ msgstr "" -#~ "La columna '{column_name}' no se " -#~ "encontró en la tabla de Datos de" -#~ " Amenazas para el escenario LULC de" -#~ " input correspondiente." +#~ "La columna '{column_name}' no se encontró en la tabla de Datos de Amenazas " +#~ "para el escenario LULC de input correspondiente." #~ msgid "" -#~ "Map of the threat's distribution in " -#~ "the future scenario. Each pixel value" -#~ " is the relative intensity of the " -#~ "threat at that location. Required if " -#~ "Future LULC is provided." +#~ "Map of the threat's distribution in the future scenario. Each pixel value is " +#~ "the relative intensity of the threat at that location. Required if Future " +#~ "LULC is provided." #~ msgstr "" -#~ "Mapa de la distribución de la " -#~ "amenaza en el escenario futuro. El " -#~ "valor de cada píxel es la " -#~ "intensidad relativa de la amenaza en " -#~ "ese lugar. Se requiere si se " -#~ "proporciona el LULC futuro." +#~ "Mapa de la distribución de la amenaza en el escenario futuro. El valor de " +#~ "cada píxel es la intensidad relativa de la amenaza en ese lugar. Se requiere " +#~ "si se proporciona el LULC futuro." #~ msgid "LULC codes corresponding to those in the LULC rasters." #~ msgstr "Códigos LULC correspondientes a los de los rásters LULC." @@ -6135,9 +6148,8 @@ msgstr "" #~ msgid "File could not be opened as a CSV. File must be encoded as a UTF-8 CSV." #~ msgstr "" -#~ "El archivo no se ha podido abrir" -#~ " como CSV. El archivo debe estar " -#~ "codificado como un CSV UTF-8." +#~ "El archivo no se ha podido abrir como CSV. El archivo debe estar codificado " +#~ "como un CSV UTF-8." #~ msgid "Bounding boxes do not intersect: {bboxes}" #~ msgstr "Las cajas delimitadoras no se cruzan: {bboxes}" @@ -6146,26 +6158,18 @@ msgstr "" #~ msgstr "Capacidad máxima del dispositivo." #~ msgid "" -#~ "Upper limit of wave height for " -#~ "device operation. The device shuts down" -#~ " when waves are higher than this." +#~ "Upper limit of wave height for device operation. The device shuts down when " +#~ "waves are higher than this." #~ msgstr "" -#~ "Límite superior de la altura de " -#~ "las olas para el funcionamiento del " -#~ "dispositivo. El dispositivo se apaga " -#~ "cuando las olas son más altas que" -#~ " esto." +#~ "Límite superior de la altura de las olas para el funcionamiento del " +#~ "dispositivo. El dispositivo se apaga cuando las olas son más altas que esto." #~ msgid "" -#~ "Upper limit of wave period for " -#~ "device operation. The device shuts down" -#~ " when the wave period is longer " -#~ "than this." +#~ "Upper limit of wave period for device operation. The device shuts down when " +#~ "the wave period is longer than this." #~ msgstr "" -#~ "Límite superior del periodo de onda " -#~ "para el funcionamiento del aparato. El" -#~ " dispositivo se apaga cuando el " -#~ "periodo de onda es mayor que este." +#~ "Límite superior del periodo de onda para el funcionamiento del aparato. El " +#~ "dispositivo se apaga cuando el periodo de onda es mayor que este." #~ msgid "Maximum capacity of the device." #~ msgstr "Capacidad máxima del dispositivo." @@ -6196,9 +6200,7 @@ msgstr "" #~ msgid "LULC code for this class corresponding to values in the LULC raster." #~ msgstr "" -#~ "Código LULC para esta clase " -#~ "correspondiente a los valores del ráster" -#~ " LULC." +#~ "Código LULC para esta clase correspondiente a los valores del ráster LULC." #~ msgid "{number} features have a non-integer ws_id field" #~ msgstr "{number} las características tienen un campo ws_id no entero" @@ -6208,4 +6210,3 @@ msgstr "" #~ msgid "LULC code matching those in the LULC raster." #~ msgstr "Código LULC que coincide con los del ráster LULC." - From 8f8c9a6fb946328559a9f90f2cd0fc8db5f017ee Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 29 Apr 2024 10:23:01 -0700 Subject: [PATCH 14/90] add new workbench translations for ES --- workbench/src/main/i18n/es.json | 18 +- workbench/src/renderer/i18n/es.json | 270 ++++++++++++++-------------- 2 files changed, 144 insertions(+), 144 deletions(-) diff --git a/workbench/src/main/i18n/es.json b/workbench/src/main/i18n/es.json index 995c775dde..c40c4dcb25 100644 --- a/workbench/src/main/i18n/es.json +++ b/workbench/src/main/i18n/es.json @@ -1,10 +1,10 @@ { - "File": "", - "Edit": "", - "Speech": "", - "View": "", - "Window": "", - "About": "", - "About InVEST": "", - "Report a problem": "" -} + "File": "Archivo", + "Edit": "Edición", + "Speech": "Dicción", + "View": "Vista", + "Window": "Ventana", + "About": "Acerca de", + "About InVEST": "Acerca de InVEST", + "Report a problem": "Informe de un problema" +} \ No newline at end of file diff --git a/workbench/src/renderer/i18n/es.json b/workbench/src/renderer/i18n/es.json index 18d633c3f5..6b6b2cb8ee 100644 --- a/workbench/src/renderer/i18n/es.json +++ b/workbench/src/renderer/i18n/es.json @@ -1,136 +1,136 @@ { - "Annual Water Yield": "", - "Carbon Storage and Sequestration": "", - "Coastal Blue Carbon": "", - "Coastal Vulnerability": "", - "Crop Pollination": "", - "Crop Production": "", - "DelineateIt": "", - "Forest Carbon Edge Effect": "", - "Habitat Quality": "", - "Habitat Risk Assessment": "", - "Nutrient Delivery Ratio": "", - "RouteDEM": "", - "Scenario Generator: Proximity Based": "", - "Scenic Quality": "", - "Seasonal Water Yield": "", - "Sediment Delivery Ratio": "", - "Urban Stormwater Retention": "", - "Urban Cooling": "", - "Urban Flood Risk Mitigation": "", - "Urban Nature Access": "", - "Visitation: Recreation and Tourism": "", - "Wave Energy Production": "", - "Wind Energy Production": "", - "Global DEM & Landmass Polygon": "", - "(recommended to run model)": "", - "(required to run model)": "", - "(required for Wind & Wave Energy)": "", - "Please choose a different folder. This application does not have permission to write to folder:": "", - "Download InVEST sample data": "Descargar datos de muestra de InVEST", - "Cancel": "Cancelar", - "Download": "Descargar", - "Download Failed": "Falló la descarga", - "Download Complete": "Descarga completa", - "Downloading {{number}} of {{nTotal}}": "", - "Something went wrong": "Algo salió mal", - "Please help us fix this by reporting the problem.You may follow these steps:": "", - "Find the Workbench log files using the button below.": "", - "There may be multiple files with a \".log\" extension.": "", - "Find My Logs": "Encontrar mis registros", - "Create a post on our forum ": "Crear un mensaje en nuestro foro", - "and upload all the log files, along with a brief description of what happened before you saw this message.": "y suba todos los archivos de registro, junto con una breve descripción de lo que ocurrió antes de ver este mensaje.", - "Model Complete": "Modelo completo", - "Recent runs:": "Corridas recientes:", - "Set up a model from a sample datastack file (.json) or from an InVEST model's logfile (.txt): ": "Configure un modelo a partir de un archivo Datastack de ejemplo (.json) o del archivo de registro de un modelo InVEST (.txt)", - "Setup": "Configuración", - "Log": "Registro", - "Open Workspace": "Abrir el espacio de trabajo", - "Cancel Run": "Cancelar la ejecución", - "Error: see log for details": "Error: ver el registro para más detalles", - "Run Canceled": "Ejecución cancelada", - "No InVEST model data can be parsed from the file:": "", - "Browse to a datastack (.json) or InVEST logfile (.txt)": "Buscar una pila de datos (.json) o un archivo de registro InVEST (.txt)", - "Open": "Abrir", - "User's Guide": "Guía de uso", - "Frequently Asked Questions": "Preguntas frecuentes", - "Save as...": "Guardar como...", - "Datastack options": "Opciones de Datastack", - "Save your parameters in a JSON file. This includes the paths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "Guarde sus parámetros en un archivo JSON. Esto incluye las rutas a los datos de entrada, pero no los datos en sí. Abra este archivo en InVEST para restaurar sus parámetros.", - "Save your parameters and input data in a compressed archive. This archive contains the same JSON file produced by the \"Parameters only\" option, plus the data. You can open this file in InVEST to restore your parameters. This option is useful to copy all the necessary data to a different location.": "Guarde sus parámetros y datos de entrada en un archivo comprimido. Este archivo contiene el mismo archivo JSON producido por la opción \"Sólo parámetros\", además de los datos. Puede abrir este archivo en InVEST para restaurar sus parámetros. Esta opción es útil para copiar todos los datos necesarios en una ubicación diferente.", - "Save your parameters in a python script. This includes the paths to your input data, but not the data itself. Running the python script will programmatically run the model with your parameters. Use this as a starting point for batch scripts.": "Guarde sus parámetros en un script de Python. Esto incluye las rutas a los datos de entrada, pero no los datos en sí. Al ejecutar el script de Python, el modelo se ejecutará mediante programación con sus parámetros. Utilícelo como punto de partida para scripts por lotes.", - "Save": "", - "Synchronous": "", - "Threaded task management": "", - "CPUs": "", - "DEBUG": "", - "INFO": "", - "WARNING": "", - "ERROR": "", - "InVEST Settings": "Configuración de InVEST", - "Language": "Idioma", - "Logging threshold": "Umbral de registro", - "Taskgraph logging threshold": "Umbral de registro del gráfico de tareas", - "Taskgraph n_workers parameter": "Parámetro n_workers del gráfico de tareas", - "more info": "", - "synchronous task execution is most reliable": "la ejecución de tareas sincrónicas es la más fiable", - "threaded task management: tasks execute only in the main process, using multiple threads.": "gestión de tareas por hilos: las tareas se ejecutan solo en el proceso principal, utilizando varios hilos.", - "n CPUs: depending on the InVEST model, tasks may execute in parallel using up to this many processes.": "n CPUs: dependiendo del modelo de InVEST, las tareas pueden ejecutarse en paralelo utilizando hasta este número de procesos.", - "Download Sample Data": "Descargar datos de muestra", - "Clear Recent Jobs": "Borrar trabajos recientes", - "no invest workspaces will be deleted": "no se eliminará ningún espacio de trabajo de InVEST", - "Warning": "", - "Changing this setting will close your tabs and relaunch the app.": "", - "Change to ": "", - "Not all of the spatial layers overlap each other. Bounding box:": "", - "optional": "", - "boolean": "", - "integer": "", - "csv": "", - "directory": "", - "file": "", - "freestyle_string": "", - "number": "", - "option_string": "", - "percent": "", - "raster": "", - "ratio": "", - "vector": "", - "text": "texto", - "percent: a number from 0 - 100": "porcentaje: un número de 0 a 100", - "ratio: a decimal from 0 - 1": "tasa: un decimal de 0 - 1", - "User's guide entry": "Entrada de la guía del usuario", - "Only drop one file at a time.": "Solo se puede soltar un archivo a la vez.", - "Choose location to extract archive": "", - "Datastack/Logfile for {{modelName}} does not match this model.": "", - "Running": "En curso", - "Run": "Ejecutar", - "Browse to a datastack (.json, .tgz) or InVEST logfile (.txt)": "Buscar una pila de datos (.json, .tgz) o un archivo de registro InVEST (.txt)", - "Load parameters from file": "Cargar los parámetros desde un archivo", - "No args to see here": "No hay argumentos que ver aquí", - "version:": "", - "Copyright 2023, The Natural Capital Project": "", - "Documentation": "", - "Homepage": "", - "Project page": "", - "License": "", - "InVEST Trademark and Logo Use Policy": "", - "Open-Source Licenses:": "", - "MIT and others": "", - "Please help us by reporting problems.": "", - "If the problem is related to a specific InVEST model, ": "", - "please see the guidelines here for reporting problems: ": "", - "Guidelines for posting software support questions": "", - "If the problem is related to this User Interface, ": "", - "rather than with a specific InVEST model,": "", - "Consider taking a screenshot of the problem.": "", - "Find the log files using the button below. There may be multiple files with a \".log\" extension; please include them all.": "", - "Create a post on our forum and upload these items, along with a brief description of the problem.": "", - "Save your parameters in a JSON file. This includes thepaths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "", - "Reset to Defaults": "Valores predeterminados", - "Bounding box does not intersect at least one other:": "La caja delimitadora no se interseca al menos con otra:", - "InVEST": "InVEST", - "Find the Workbench log files ": "Buscar los archivos de registro de Workbench", - "Please help us fix this by reporting the problem. You may follow these steps:": "Por favor, ayúdenos a solucionar esto informando del problema. Puede seguir estos pasos:", - "using the button below. There may be multiple files with a \".log\" extension.": "con el botón de abajo. Puede haber varios archivos con extensión \".log\"." -} + "Annual Water Yield": "Producción anual de agua", + "Carbon Storage and Sequestration": "Almacenamiento y secuestración de carbono", + "Coastal Blue Carbon": "Carbono azul costero", + "Coastal Vulnerability": "Vulnerabilidad de las costas", + "Crop Pollination": "Polinización de cultivos", + "Crop Production": "Producción de cultivos", + "DelineateIt": "DelineatIt", + "Forest Carbon Edge Effect": "Efecto de borde del carbono forestal", + "Habitat Quality": "Calidad del hábitat", + "Habitat Risk Assessment": "Evaluación de riesgo de hábitats", + "Nutrient Delivery Ratio": "Tasa de entrega de nutrientes", + "RouteDEM": "RouteDEM", + "Scenario Generator: Proximity Based": "Generador de Escenarios: Basado en Proximidad", + "Scenic Quality": "Calidad escénica", + "Seasonal Water Yield": "Producción de agua estacional", + "Sediment Delivery Ratio": "Tasa de entrega de sedimentos", + "Urban Stormwater Retention": "Retención urbana de agua de tormenta", + "Urban Cooling": "Enfriamiento urbano", + "Urban Flood Risk Mitigation": "Mitigación de riesgos de inundaciones urbanas", + "Urban Nature Access": "Acceso urbano a la naturaleza", + "Visitation: Recreation and Tourism": "Visitación: recreación y turismo", + "Wave Energy Production": "Producción de energía de olas", + "Wind Energy Production": "Producción de energía eólica", + "Global DEM & Landmass Polygon": "MED Global y Polígono de Masa Terrestre", + "(recommended to run model)": "(se recomienda para que corra el modelo)", + "(required to run model)": "(se requiere para que corra el modelo)", + "(required for Wind & Wave Energy)": "(se requiere para Energía Eólica y de Olas)", + "Please choose a different folder. This application does not have permission to write to folder:": "Por favor, seleccione una carpeta diferente. Esta aplicación no tiene permiso para escribir en la carpeta:", + "Download InVEST sample data": "Descargar datos de muestra de InVEST", + "Cancel": "Cancelar", + "Download": "Descargar", + "Download Failed": "Falló la descarga", + "Download Complete": "Descarga completa", + "Downloading {{number}} of {{nTotal}}": "Descargando {{number}} of {{nTotal}}", + "Something went wrong": "Algo salió mal", + "Please help us fix this by reporting the problem.You may follow these steps:": "Por favor, ayúdenos a reparar esto informando sobre el problema. Puede seguir estos pasos:", + "Find the Workbench log files using the button below.": "Halle los archivos de registro Workbench usando el botón de abajo.", + "There may be multiple files with a \".log\" extension.": "Puede haber varios archivos con una extensión \".log\".", + "Find My Logs": "Encontrar mis registros", + "Create a post on our forum ": "Genere un mensaje en nuestro foro ", + "and upload all the log files, along with a brief description of what happened before you saw this message.": "y suba todos los archivos de registro, junto con una breve descripción de lo que ocurrió antes de ver este mensaje.", + "Model Complete": "Modelo completo", + "Recent runs:": "Corridas recientes:", + "Set up a model from a sample datastack file (.json) or from an InVEST model's logfile (.txt): ": "Configure un modelo a partir de un archivo Datastack de ejemplo (.json) o del archivo de registro de un modelo InVEST (.txt) ", + "Setup": "Configuración", + "Log": "Registro", + "Open Workspace": "Abrir el espacio de trabajo", + "Cancel Run": "Cancelar la ejecución", + "Error: see log for details": "Error: ver el registro para más detalles", + "Run Canceled": "Ejecución cancelada", + "No InVEST model data can be parsed from the file:": "No hay datos de modelos InVEST que puedan ser analizados desde el archivo:", + "Browse to a datastack (.json) or InVEST logfile (.txt)": "Buscar una pila de datos (.json) o un archivo de registro InVEST (.txt)", + "Open": "Abrir", + "User's Guide": "Guía de uso", + "Frequently Asked Questions": "Preguntas frecuentes", + "Save as...": "Guardar como...", + "Datastack options": "Opciones de Datastack", + "Save your parameters in a JSON file. This includes the paths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "Guarde sus parámetros en un archivo JSON. Esto incluye las rutas a los datos de entrada, pero no los datos en sí. Abra este archivo en InVEST para restaurar sus parámetros.", + "Save your parameters and input data in a compressed archive. This archive contains the same JSON file produced by the \"Parameters only\" option, plus the data. You can open this file in InVEST to restore your parameters. This option is useful to copy all the necessary data to a different location.": "Guarde sus parámetros y datos de entrada en un archivo comprimido. Este archivo contiene el mismo archivo JSON producido por la opción \"Sólo parámetros\", además de los datos. Puede abrir este archivo en InVEST para restaurar sus parámetros. Esta opción es útil para copiar todos los datos necesarios en una ubicación diferente.", + "Save your parameters in a python script. This includes the paths to your input data, but not the data itself. Running the python script will programmatically run the model with your parameters. Use this as a starting point for batch scripts.": "Guarde sus parámetros en un script de Python. Esto incluye las rutas a los datos de entrada, pero no los datos en sí. Al ejecutar el script de Python, el modelo se ejecutará mediante programación con sus parámetros. Utilícelo como punto de partida para scripts por lotes.", + "Save": "Guardar", + "Synchronous": "Sincrónico", + "Threaded task management": "Manejo encadenado de tareas", + "CPUs": "CPUs", + "DEBUG": "DEPURAR", + "INFO": "INFORMACIÓN", + "WARNING": "ADVERTENCIA", + "ERROR": "ERROR", + "InVEST Settings": "Configuración de InVEST", + "Language": "Idioma", + "Logging threshold": "Umbral de registro", + "Taskgraph logging threshold": "Umbral de registro del gráfico de tareas", + "more info": "más información", + "synchronous task execution is most reliable": "la ejecución sincrónica de tareas es la más fiable", + "threaded task management: tasks execute only in the main process, using multiple threads.": "gestión de tareas por hilos: las tareas se ejecutan solo en el proceso principal, utilizando varios hilos.", + "n CPUs: depending on the InVEST model, tasks may execute in parallel using up to this many processes.": "n CPUs: dependiendo del modelo de InVEST, las tareas pueden ejecutarse en paralelo utilizando hasta este número de procesos.", + "Download Sample Data": "Descargar datos de muestra", + "Clear Recent Jobs": "Borrar trabajos recientes", + "no invest workspaces will be deleted": "no se eliminará ningún espacio de trabajo de InVEST", + "Warning": "Advertencia", + "Changing this setting will close your tabs and relaunch the app.": "Cambiar esta opciín cerrará las pestañas y relanzará la aplicación.", + "Change to ": "Cambiar a ", + "Not all of the spatial layers overlap each other. Bounding box:": "No todas las capas espaciales se traslapan entre ellas. Caja delmitadora:", + "optional": "opcional", + "boolean": "booleano", + "integer": "entero", + "csv": "csv", + "directory": "directorio", + "file": "archivo", + "number": "número", + "percent": "porcentaje", + "raster": "ráster", + "ratio": "tasa", + "vector": "vector", + "text": "texto", + "percent: a number from 0 - 100": "porcentaje: un número de 0 a 100", + "ratio: a decimal from 0 - 1": "tasa: un decimal de 0 - 1", + "User's guide entry": "Entrada de la guía del usuario", + "Only drop one file at a time.": "Solo se puede soltar un archivo a la vez.", + "Choose location to extract archive": "Seleccione la ubicación donde extraer el archivo", + "Datastack/Logfile for {{modelName}} does not match this model.": "Datastack/Logfile para {{modelName}} no calza con este modelo.", + "Running": "En curso", + "Run": "Ejecutar", + "Browse to a datastack (.json, .tgz) or InVEST logfile (.txt)": "Buscar una pila de datos (.json, .tgz) o un archivo de registro InVEST (.txt)", + "Load parameters from file": "Cargar los parámetros desde un archivo", + "No args to see here": "No hay argumentos que ver aquí", + "version:": "versión:", + "Copyright 2023, The Natural Capital Project": "Copyright 2023, The Natural Capital Project", + "Documentation": "Documentación", + "Homepage": "Página web", + "Project page": "Página del proyecto", + "License": "Licencia", + "InVEST Trademark and Logo Use Policy": "Política de uso de la marca y el logotipo de InVEST", + "Open-Source Licenses:": "Licencias de código abierto:", + "MIT and others": "MIT y otros", + "Please help us by reporting problems.": "Por favor, ayúdenos informando sobre problemas.", + "If the problem is related to a specific InVEST model, ": "Si el problema se relaciona con un modelo InVEST específico, ", + "please see the guidelines here for reporting problems: ": "por favor, refiérase a la guía para informar sobre problemas aquí: ", + "Guidelines for posting software support questions": "Guía para publicar preguntas de apoyo sobre software", + "If the problem is related to this User Interface, ": "Si el problema se relaciona con esta interfaz de uso, ", + "rather than with a specific InVEST model,": "más que con un modelo InVEST específico,", + "Consider taking a screenshot of the problem.": "Considere hacer una captura de pantalla del problema.", + "Find the log files using the button below. There may be multiple files with a \".log\" extension; please include them all.": "Halle los archivos de registro usando el botón más abajo. Podría haber varios archivos con una extensión \".log\"; por favor, incluya todos ellos.", + "Create a post on our forum and upload these items, along with a brief description of the problem.": "Cree un posteo en nuestro foro y cargue estos ítemes junto a una breve descripción del problema.", + "Save your parameters in a JSON file. This includes thepaths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "Guarde sus parámetros en un archivo JSON. Esto incluye las rutas a sus datos de entrada, pero no los datos en sí. Abra este archivo en InVEST para reestablecer sus parámetros.", + "Reset to Defaults": "Valores predeterminados", + "Bounding box does not intersect at least one other:": "La caja delimitadora no se interseca al menos con otra:", + "InVEST": "InVEST", + "Find the Workbench log files ": "Buscar los archivos de registro de Workbench ", + "Please help us fix this by reporting the problem. You may follow these steps:": "Por favor, ayúdenos a solucionar esto informando del problema. Puede seguir estos pasos:", + "using the button below. There may be multiple files with a \".log\" extension.": "con el botón de abajo. Puede haber varios archivos con extensión \".log\".", + "Taskgraph n_workers parameter": "Parámetro n_workers del gráfico de tareas", + "freestyle_string": "freestyle", + "option_string": "option" +} \ No newline at end of file From 276c74c71b9425e0960ed81290aa78863c58ad4a Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Mon, 29 Apr 2024 10:52:41 -0700 Subject: [PATCH 15/90] add no-python-format flag to gettext strings with percents --- .../locales/es/LC_MESSAGES/messages.po | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po b/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po index 6414e583cd..9396b609bf 100644 --- a/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po +++ b/src/natcap/invest/internationalization/locales/es/LC_MESSAGES/messages.po @@ -428,7 +428,7 @@ msgstr "Debe ser una geometría de punto o multipunto." # In all this there is some coding error I don´t get. The translation itself # is correct. #: src/natcap/invest/coastal_vulnerability.py:93 -#, python-format +#, no-python-format msgid "" "Proportion of the highest 10% of wind speeds in the record of interest that blow " "in the direction of each sector." @@ -437,7 +437,7 @@ msgstr "" "interés que soplan en la dirección de cada sector." #: src/natcap/invest/coastal_vulnerability.py:100 -#, python-format +#, no-python-format msgid "" "Average of the highest 10% of wind speeds that blow in the direction of each " "sector." @@ -446,7 +446,7 @@ msgstr "" "dirección de cada sector." #: src/natcap/invest/coastal_vulnerability.py:105 -#, python-format +#, no-python-format msgid "" "Proportion of the highest 10% of wave power values on record that are in each " "sector." @@ -455,7 +455,7 @@ msgstr "" "se encuentran en cada sector." #: src/natcap/invest/coastal_vulnerability.py:111 -#, python-format +#, no-python-format msgid "" "Average of the highest 10% of wave power values on record in the direction of " "each sector." @@ -464,7 +464,7 @@ msgstr "" "dirección de cada sector." #: src/natcap/invest/coastal_vulnerability.py:116 -#, fuzzy, python-format +#, fuzzy, no-python-format msgid "" "Average of the highest 10% of wind speeds that are centered on each main sector " "direction X." From e39420927e305b58b7119abe5aec802e4a089e99 Mon Sep 17 00:00:00 2001 From: James Douglass Date: Thu, 26 Sep 2024 12:06:11 -0700 Subject: [PATCH 16/90] Using the known nodata value and float32 dtype. RE:#1635 --- HISTORY.rst | 8 ++++++++ src/natcap/invest/pollination.py | 21 ++++++++++++++++----- 2 files changed, 24 insertions(+), 5 deletions(-) diff --git a/HISTORY.rst b/HISTORY.rst index dfa49b3025..348fd1442a 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -37,6 +37,14 @@ Unreleased Changes ------------------ +* Pollination + * Fixed an issue with nodata handling that was causing some outputs to be + filled either with the float32 value for positive infinity, or else with + a value very close to it. https://github.com/natcap/invest/issues/1635 + * While working on https://github.com/natcap/invest/issues/1635, we also + updated the stated dtype of most pollination model outputs to be float32 + instead of the float64 dtype that was being assumed previously. This + will result in smaller output filesizes with minimal loss of precision. * Workbench * Several small updates to the model input form UI to improve usability and visual consistency (https://github.com/natcap/invest/issues/912) diff --git a/src/natcap/invest/pollination.py b/src/natcap/invest/pollination.py index 60def5ec3e..e845f2180a 100644 --- a/src/natcap/invest/pollination.py +++ b/src/natcap/invest/pollination.py @@ -855,6 +855,7 @@ def execute(args): floral_resources_index_path_map[species], convolve_ps_path], target_path=pollinator_abundance_path, + target_dtype=numpy.float32, target_nodata=_INDEX_NODATA), dependent_task_list=[ foraged_flowers_index_task_map[(species, season)], @@ -935,7 +936,9 @@ def execute(args): rasters=[ half_saturation_raster_path, total_pollinator_abundance_index_path], - target_path=farm_pollinator_season_path), + target_path=farm_pollinator_season_path, + target_dtype=numpy.float32, + target_nodata=_INDEX_NODATA), dependent_task_list=[ half_saturation_task, total_pollinator_abundance_task[season]], target_path_list=[farm_pollinator_season_path])) @@ -976,7 +979,9 @@ def execute(args): kwargs=dict( op=pyt_op, rasters=[managed_pollinator_path, farm_pollinator_path], - target_path=total_pollinator_yield_path), + target_path=total_pollinator_yield_path, + target_dtype=numpy.float32, + target_nodata=_INDEX_NODATA), dependent_task_list=[farm_pollinator_task, managed_pollinator_task], target_path_list=[total_pollinator_yield_path]) @@ -984,12 +989,14 @@ def execute(args): wild_pollinator_yield_path = os.path.join( output_dir, _WILD_POLLINATOR_YIELD_FILE_PATTERN % file_suffix) wild_pollinator_task = task_graph.add_task( - task_name='calcualte_wild_pollinators', + task_name='calculate_wild_pollinators', func=pygeoprocessing.raster_map, kwargs=dict( op=pyw_op, rasters=[managed_pollinator_path, total_pollinator_yield_path], - target_path=wild_pollinator_yield_path), + target_path=wild_pollinator_yield_path, + target_dtype=numpy.float32, + target_nodata=_INDEX_NODATA), dependent_task_list=[pyt_task, managed_pollinator_task], target_path_list=[wild_pollinator_yield_path]) @@ -1392,7 +1399,8 @@ def _sum_arrays(*array_list): result = numpy.empty_like(array_list[0]) result[:] = 0 for array in array_list: - local_valid_mask = ~pygeoprocessing.array_equals_nodata(array, _INDEX_NODATA) + local_valid_mask = ~pygeoprocessing.array_equals_nodata( + array, _INDEX_NODATA) result[local_valid_mask] += array[local_valid_mask] valid_mask |= local_valid_mask result[~valid_mask] = _INDEX_NODATA @@ -1423,6 +1431,7 @@ def max_op(*substrate_index_arrays): pygeoprocessing.raster_map( op=max_op, rasters=substrate_path_list, + target_dtype=numpy.float32, target_path=target_habitat_nesting_index_path) @@ -1432,6 +1441,7 @@ def _multiply_by_scalar(raster_path, scalar, target_path): op=lambda array: array * scalar, rasters=[raster_path], target_path=target_path, + target_dtype=numpy.float32, target_nodata=_INDEX_NODATA, ) @@ -1455,6 +1465,7 @@ def _calculate_pollinator_supply_index( op=lambda f_r, h_n: species_abundance * f_r * h_n, rasters=[habitat_nesting_suitability_path, floral_resources_path], target_path=target_path, + target_dtype=numpy.float32, target_nodata=_INDEX_NODATA ) From e4cee566afda5c7b504f9d7208ba46d7488bef0d Mon Sep 17 00:00:00 2001 From: James Douglass Date: Thu, 26 Sep 2024 13:46:42 -0700 Subject: [PATCH 17/90] Seeing if env marker handling corrects pip installation issues. RE:#1635 --- scripts/convert-requirements-to-conda-yml.py | 52 +++++++++++++++++++- 1 file changed, 51 insertions(+), 1 deletion(-) diff --git a/scripts/convert-requirements-to-conda-yml.py b/scripts/convert-requirements-to-conda-yml.py index e5e2bc2d57..594a821a6a 100644 --- a/scripts/convert-requirements-to-conda-yml.py +++ b/scripts/convert-requirements-to-conda-yml.py @@ -2,6 +2,7 @@ """convert-requirements-to-conda-yml.py""" import argparse +import os import platform import sys @@ -14,6 +15,46 @@ """ +# Environment marker handling is taken straight from +# https://peps.python.org/pep-0508/#environment-markers +def _get_implementation_version(): + def format_full_version(info): + version = '{0.major}.{0.minor}.{0.micro}'.format(info) + kind = info.releaselevel + if kind != 'final': + version += kind[0] + str(info.serial) + return version + + if hasattr(sys, 'implementation'): + implementation_version = format_full_version( + sys.implementation.version) + else: + implementation_version = "0" + return implementation_version + + +# Environment marker handling is taken straight from +# https://peps.python.org/pep-0508/#environment-markers +ENV_MARKERS = { + "os_name": os.name(), + "sys_platform": sys.platform, + "platform_machine": platform.machine(), + "platform_python_impl": platform.python_implementation(), + "platform_release": platform.release(), + "platform_system": platform.system(), + "platform_version": platform.version(), + + # Deliberately not supporting python_version marker in order to avoid + # possible issues with the python version not yet being known when this + # script is run. + # "python_version": '.'.join(platform.python_version_tuple()[:2]), + + "python_full_version": platform.python_version(), + "implementation_name": sys.implementation.name, + "implementation_version": _get_implementation_version(), +} + + def build_environment_from_requirements(cli_args): """Build a conda environment.yml from requirements.txt files. @@ -62,7 +103,16 @@ def build_environment_from_requirements(cli_args): # requirement if we're using pip. conda_requirements.add('pip') - pip_requirements.add(line) + # Handle environment specifiers and see if the requirement + # should exist in this environment. + # InVEST pretty much just uses this for checking operating + # systems. + if ";" in line: + package, marker = line.split(';') + if eval(marker, ENV_MARKERS): + pip_requirements.add(package) + else: + pip_requirements.add(line) # If an scm needs to be installed for pip to clone to a # revision, add it to the conda package list. From 9d4646735f2d346ed21f60ecc669dc64321d467d Mon Sep 17 00:00:00 2001 From: James Douglass Date: Thu, 26 Sep 2024 13:49:41 -0700 Subject: [PATCH 18/90] Correcting an environment marker that is not a function. RE:#1635 --- scripts/convert-requirements-to-conda-yml.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/scripts/convert-requirements-to-conda-yml.py b/scripts/convert-requirements-to-conda-yml.py index 594a821a6a..f3c6e51da2 100644 --- a/scripts/convert-requirements-to-conda-yml.py +++ b/scripts/convert-requirements-to-conda-yml.py @@ -36,7 +36,7 @@ def format_full_version(info): # Environment marker handling is taken straight from # https://peps.python.org/pep-0508/#environment-markers ENV_MARKERS = { - "os_name": os.name(), + "os_name": os.name, "sys_platform": sys.platform, "platform_machine": platform.machine(), "platform_python_impl": platform.python_implementation(), From 82b3d43b459406cc3f81e637a4ccb126a0bb54ef Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Wed, 2 Oct 2024 15:53:56 -0700 Subject: [PATCH 19/90] add new translations for zh --- .../locales/zh/LC_MESSAGES/messages.po | 2432 ++++++----------- workbench/src/main/i18n/zh.json | 18 +- workbench/src/renderer/i18n/zh.json | 292 +- 3 files changed, 939 insertions(+), 1803 deletions(-) diff --git a/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po b/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po index f32207e79a..7fda63c567 100644 --- a/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po +++ b/src/natcap/invest/internationalization/locales/zh/LC_MESSAGES/messages.po @@ -8,39 +8,31 @@ msgstr "" "Project-Id-Version: InVEST 3.12\n" "Report-Msgid-Bugs-To: jdouglass@stanford.edu\n" "POT-Creation-Date: 2024-03-26 09:24-0700\n" -"PO-Revision-Date: 2023-03-16 14:02-0700\n" +"PO-Revision-Date: 2024-05-08 15:22+0800\n" "Last-Translator: \n" -"Language: zh\n" "Language-Team: zh \n" -"Plural-Forms: nplurals=1; plural=0;\n" +"Language: zh\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" +"Plural-Forms: nplurals=1; plural=0;\n" "Generated-By: Babel 2.14.0\n" +"X-Generator: Poedit 3.4.2\n" -#: src/natcap/invest/annual_water_yield.py:92 -#: src/natcap/invest/annual_water_yield.py:186 +#: src/natcap/invest/annual_water_yield.py:92 src/natcap/invest/annual_water_yield.py:186 msgid "Unique identifier for each subwatershed." msgstr "每个流域的唯一标识符。" -#: src/natcap/invest/annual_water_yield.py:101 -#: src/natcap/invest/annual_water_yield.py:170 +#: src/natcap/invest/annual_water_yield.py:101 src/natcap/invest/annual_water_yield.py:170 msgid "Unique identifier for each watershed." msgstr "每个流域的唯一标识符。" -#: src/natcap/invest/annual_water_yield.py:129 -#: src/natcap/invest/forest_carbon_edge_effect.py:115 -#: src/natcap/invest/sdr/sdr.py:74 -msgid "" -"All values in this raster must have corresponding entries in the " -"Biophysical Table." +#: src/natcap/invest/annual_water_yield.py:129 src/natcap/invest/forest_carbon_edge_effect.py:115 src/natcap/invest/sdr/sdr.py:74 +msgid "All values in this raster must have corresponding entries in the Biophysical Table." msgstr "该栅格中的所有数值必须在生物物理表中有相应的条目。" #: src/natcap/invest/annual_water_yield.py:140 -msgid "" -"Map of root restricting layer depth, the soil depth at which root " -"penetration is strongly inhibited because of physical or chemical " -"characteristics." +msgid "Map of root restricting layer depth, the soil depth at which root penetration is strongly inhibited because of physical or chemical characteristics." msgstr "根系限制层深度图,由于物理或化学特性,根系渗透受到强烈抑制的土壤深度。" #: src/natcap/invest/annual_water_yield.py:144 @@ -48,9 +40,7 @@ msgid "root restricting layer depth" msgstr "根系限制层的深度" #: src/natcap/invest/annual_water_yield.py:154 -msgid "" -"Map of plant available water content, the fraction of water that can be " -"stored in the soil profile that is available to plants." +msgid "Map of plant available water content, the fraction of water that can be stored in the soil profile that is available to plants." msgstr "植物可用水分含量图,即可储存在土壤剖面中的、可供植物使用的那部分水。" #: src/natcap/invest/annual_water_yield.py:158 @@ -58,9 +48,7 @@ msgid "plant available water content" msgstr "植物可用水分含量" #: src/natcap/invest/annual_water_yield.py:174 -msgid "" -"Map of watershed boundaries, such that each watershed drains to a point " -"of interest where hydropower production will be analyzed." +msgid "Map of watershed boundaries, such that each watershed drains to a point of interest where hydropower production will be analyzed." msgstr "流域边界图,以便每个流域排水到一个兴趣点,在那里水电生产将被分析。" #: src/natcap/invest/annual_water_yield.py:178 src/natcap/invest/ndr/ndr.py:73 @@ -68,9 +56,7 @@ msgid "watersheds" msgstr "流域" #: src/natcap/invest/annual_water_yield.py:191 -msgid "" -"Map of subwatershed boundaries within each watershed in the Watersheds " -"map." +msgid "Map of subwatershed boundaries within each watershed in the Watersheds map." msgstr "流域地图中每个流域内的小流域边界图。" #: src/natcap/invest/annual_water_yield.py:194 @@ -79,44 +65,30 @@ msgstr "流域" #: src/natcap/invest/annual_water_yield.py:202 msgid "" -"Code indicating whether the the LULC class is vegetated for the purpose " -"of AET. Enter 1 for all vegetated classes except wetlands, and 0 for all " -"other classes, including wetlands, urban areas, water bodies, etc." +"Code indicating whether the the LULC class is vegetated for the purpose of AET. Enter 1 for all vegetated classes except wetlands, and 0 for all other classes, " +"including wetlands, urban areas, water bodies, etc." msgstr "表示LULC等级是否为植被的代码,用于AET的目的。除湿地外,所有植被等级均为1,所有其他等级均为0,包括湿地、城市区域、水体等。" #: src/natcap/invest/annual_water_yield.py:212 -msgid "" -"Maximum root depth for plants in this LULC class. Only used for classes " -"with a 'lulc_veg' value of 1." +msgid "Maximum root depth for plants in this LULC class. Only used for classes with a 'lulc_veg' value of 1." msgstr "该LULC的植物最大根系深度。只用于'lulc_veg'值为1的类。" -#: src/natcap/invest/annual_water_yield.py:219 -#: src/natcap/invest/urban_cooling_model.py:65 +#: src/natcap/invest/annual_water_yield.py:219 src/natcap/invest/urban_cooling_model.py:65 msgid "Crop coefficient for this LULC class." msgstr "LULC的作物系数。" #: src/natcap/invest/annual_water_yield.py:222 -msgid "" -"Table of biophysical parameters for each LULC class. All values in the " -"LULC raster must have corresponding entries in this table." +msgid "Table of biophysical parameters for each LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "LULC生物物理参数表。LULC栅格中的所有值都必须在该表中有相应的条目。" -#: src/natcap/invest/annual_water_yield.py:226 -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:208 -#: src/natcap/invest/forest_carbon_edge_effect.py:111 -#: src/natcap/invest/ndr/ndr.py:120 src/natcap/invest/pollination.py:118 -#: src/natcap/invest/sdr/sdr.py:105 -#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:137 -#: src/natcap/invest/urban_cooling_model.py:57 -#: src/natcap/invest/urban_flood_risk_mitigation.py:77 +#: src/natcap/invest/annual_water_yield.py:226 src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:208 src/natcap/invest/forest_carbon_edge_effect.py:111 +#: src/natcap/invest/ndr/ndr.py:120 src/natcap/invest/pollination.py:118 src/natcap/invest/sdr/sdr.py:105 +#: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:137 src/natcap/invest/urban_cooling_model.py:57 src/natcap/invest/urban_flood_risk_mitigation.py:77 msgid "biophysical table" msgstr "生物物理表" #: src/natcap/invest/annual_water_yield.py:232 -msgid "" -"The seasonality factor, representing hydrogeological characterisitics and" -" the seasonal distribution of precipitation. Values typically range from " -"1 - 30." +msgid "The seasonality factor, representing hydrogeological characterisitics and the seasonal distribution of precipitation. Values typically range from 1 - 30." msgstr "季节性因子,代表水文地质特征和降水的季节分布。值的范围通常为1 - 30。" #: src/natcap/invest/annual_water_yield.py:236 @@ -132,9 +104,7 @@ msgid "Average consumptive water use in this LULC class." msgstr "LULC的平均耗水量。" #: src/natcap/invest/annual_water_yield.py:254 -msgid "" -"A table of water demand for each LULC class. Each LULC code in the LULC " -"raster must have a corresponding row in this table." +msgid "A table of water demand for each LULC class. Each LULC code in the LULC raster must have a corresponding row in this table." msgstr "每个LULC的水需求表。LULC栅格中的每个LULC代码必须在该表中有相应的条目。" #: src/natcap/invest/annual_water_yield.py:258 @@ -143,16 +113,12 @@ msgstr "水需求表" #: src/natcap/invest/annual_water_yield.py:265 msgid "" -"Unique identifier for the hydropower station. This must match the 'ws_id'" -" value for the corresponding watershed in the Watersheds vector. Each " -"watershed in the Watersheds vector must have its 'ws_id' entered in this " -"column." +"Unique identifier for the hydropower station. This must match the 'ws_id' value for the corresponding watershed in the Watersheds vector. Each watershed in the " +"Watersheds vector must have its 'ws_id' entered in this column." msgstr "水电站的唯一标识符。这必须匹配流域向量中相应流域的'ws_id'值。流域向量中的每个流域必须在这一列中输入它的“ws_id”。" #: src/natcap/invest/annual_water_yield.py:274 -msgid "" -"Turbine efficiency, the proportion of potential energy captured and " -"converted to electricity by the turbine." +msgid "Turbine efficiency, the proportion of potential energy captured and converted to electricity by the turbine." msgstr "涡轮机效率,即涡轮机捕获并转化为电能的比例。" #: src/natcap/invest/annual_water_yield.py:281 @@ -160,28 +126,19 @@ msgid "The proportion of inflow water volume that is used to generate energy." msgstr "用于发电的流入水量占总水量的比例。" #: src/natcap/invest/annual_water_yield.py:288 -msgid "" -"The head, measured as the average annual effective height of water behind" -" each dam at the turbine intake." +msgid "The head, measured as the average annual effective height of water behind each dam at the turbine intake." msgstr "水头,是指在水轮机进水口处每个大坝后的平均年有效水位。" #: src/natcap/invest/annual_water_yield.py:296 -msgid "" -"The price of power produced by the station. Must be in the same currency " -"used in the 'cost' column." +msgid "The price of power produced by the station. Must be in the same currency used in the 'cost' column." msgstr "发电站发电的价格。必须在“成本”栏中使用相同的货币。" #: src/natcap/invest/annual_water_yield.py:303 -msgid "" -"Annual maintenance and operations cost of running the hydropower station." -" Must be in the same currency used in the 'kw_price' column." +msgid "Annual maintenance and operations cost of running the hydropower station. Must be in the same currency used in the 'kw_price' column." msgstr "水电站运行年度维护运行费用。必须与“kw_price”列中使用的货币相同。" #: src/natcap/invest/annual_water_yield.py:311 -msgid "" -"Number of years over which to value the hydropower station. This is " -"either the station's expected lifespan or the duration of the land use " -"scenario of interest." +msgid "Number of years over which to value the hydropower station. This is either the station's expected lifespan or the duration of the land use scenario of interest." msgstr "为水电站估价的年数。这要么是空间站的预期寿命,要么是有关土地使用情况的持续时间。" #: src/natcap/invest/annual_water_yield.py:319 @@ -189,9 +146,7 @@ msgid "The annual discount rate, applied for each year in the time span." msgstr "年度贴现率,适用于时间跨度内的每一年。" #: src/natcap/invest/annual_water_yield.py:326 -msgid "" -"A table mapping each watershed to the associated valuation parameters for" -" its hydropower station." +msgid "A table mapping each watershed to the associated valuation parameters for its hydropower station." msgstr "将每个流域映射到其水电站的相关估值参数的表格。" #: src/natcap/invest/annual_water_yield.py:329 @@ -199,9 +154,7 @@ msgid "hydropower valuation table" msgstr "水电估价表" #: src/natcap/invest/carbon.py:59 -msgid "" -"A map of LULC for the current scenario. All values in this raster must " -"have corresponding entries in the Carbon Pools table." +msgid "A map of LULC for the current scenario. All values in this raster must have corresponding entries in the Carbon Pools table." msgstr "当前场景的LULC。该栅格中的所有值都必须在碳库表中有相应的条目。" #: src/natcap/invest/carbon.py:63 @@ -210,9 +163,8 @@ msgstr "现状LULC" #: src/natcap/invest/carbon.py:68 msgid "" -"Run sequestration analysis. This requires inputs of LULC maps for both " -"current and future scenarios. Required if REDD scenario analysis or run " -"valuation model is selected." +"Run sequestration analysis. This requires inputs of LULC maps for both current and future scenarios. Required if REDD scenario analysis or run valuation model is " +"selected." msgstr "运行固碳分析。这需要输入当前和未来情景下的LULC地图。如果选择REDD情景分析或运行估值模型,则需要。" #: src/natcap/invest/carbon.py:73 @@ -221,12 +173,11 @@ msgstr "计算封存" #: src/natcap/invest/carbon.py:80 msgid "" -"A map of LULC for the future scenario. If run valuation model is " -"selected, this should be the reference, or baseline, future scenario " -"against which to compare the REDD policy scenario. All values in this " -"raster must have corresponding entries in the Carbon Pools table. " -"Required if Calculate Sequestration is selected." -msgstr "未来情景下的LULC地图。如果选择运行评估模型,这应该是参考或基线的未来情景,用来比较REDD政策情景。该栅格中的所有数值必须在碳库表中有相应的条目。如果选择计算固存量,则需要。" +"A map of LULC for the future scenario. If run valuation model is selected, this should be the reference, or baseline, future scenario against which to compare the REDD " +"policy scenario. All values in this raster must have corresponding entries in the Carbon Pools table. Required if Calculate Sequestration is selected." +msgstr "" +"未来情景下的LULC地图。如果选择运行评估模型,这应该是参考或基线的未来情景,用来比较REDD政策情景。该栅格中的所有数值必须在碳库表中有相应的条目。如果选择计算固存量,则需" +"要。" #: src/natcap/invest/carbon.py:88 msgid "future LULC" @@ -234,9 +185,8 @@ msgstr "未来的LULC" #: src/natcap/invest/carbon.py:93 msgid "" -"Run REDD scenario analysis. This requires three LULC maps: one for the " -"current scenario, one for the future baseline scenario, and one for the " -"future REDD policy scenario." +"Run REDD scenario analysis. This requires three LULC maps: one for the current scenario, one for the future baseline scenario, and one for the future REDD policy " +"scenario." msgstr "运行REDD情景分析。这需要三张LULC地图:一张用于当前情景,一张用于未来基线情景,一张用于未来REDD政策情景。" #: src/natcap/invest/carbon.py:98 @@ -245,9 +195,8 @@ msgstr "REDD情景分析" #: src/natcap/invest/carbon.py:105 msgid "" -"A map of LULC for the REDD policy scenario. All values in this raster " -"must have corresponding entries in the Carbon Pools table. Required if " -"REDD Scenario Analysis is selected." +"A map of LULC for the REDD policy scenario. All values in this raster must have corresponding entries in the Carbon Pools table. Required if REDD Scenario Analysis is " +"selected." msgstr "REDD政策情景下的LULC地图。该栅格中的所有值必须在碳库表中有相应的条目。如果选择REDD情景分析,则需要。" #: src/natcap/invest/carbon.py:110 @@ -279,9 +228,7 @@ msgid "carbon pools" msgstr "碳库" #: src/natcap/invest/carbon.py:144 -msgid "" -"The calendar year of the current scenario depicted in the current LULC " -"map. Required if Run Valuation model is selected." +msgid "The calendar year of the current scenario depicted in the current LULC map. Required if Run Valuation model is selected." msgstr "当前LULC地图中描述的当前情景年。如果选择运行评估模型,则需要。" #: src/natcap/invest/carbon.py:147 @@ -289,15 +236,11 @@ msgid "current LULC year" msgstr "现状LULC" #: src/natcap/invest/carbon.py:154 -msgid "" -"The calendar year of the future scenario depicted in the future LULC map." -" Required if Run Valuation model is selected." +msgid "The calendar year of the future scenario depicted in the future LULC map. Required if Run Valuation model is selected." msgstr "未来LULC地图中描述的未来情景年。如果选择运行评估模式,则需要。" #: src/natcap/invest/carbon.py:162 -msgid "" -"Calculate net present value for the future scenario, and the REDD " -"scenario if provided, and report it in the final HTML document." +msgid "Calculate net present value for the future scenario, and the REDD scenario if provided, and report it in the final HTML document." msgstr "计算未来方案的净现值,如果提供REDD方案,则计算REDD方案,并在最后的HTML文件中报告。" #: src/natcap/invest/carbon.py:166 @@ -314,9 +257,8 @@ msgstr "碳的价格" #: src/natcap/invest/carbon.py:180 msgid "" -"The annual market discount rate in the price of carbon, which reflects " -"society's preference for immediate benefits over future benefits. " -"Required if Run Valuation model is selected." +"The annual market discount rate in the price of carbon, which reflects society's preference for immediate benefits over future benefits. Required if Run Valuation " +"model is selected." msgstr "碳价格中的年度市场贴现率,反映了社会对眼前利益比未来利益的偏好。如果选择运行评估模式则需要。" #: src/natcap/invest/carbon.py:185 @@ -324,9 +266,7 @@ msgid "annual market discount rate" msgstr "年度市场贴现率" #: src/natcap/invest/carbon.py:190 -msgid "" -"The relative annual increase of the price of carbon. Required if Run " -"Valuation model is selected." +msgid "The relative annual increase of the price of carbon. Required if Run Valuation model is selected." msgstr "碳价格的相对年度增长。如果选择运行评估模型,则需要。" #: src/natcap/invest/carbon.py:193 @@ -347,37 +287,27 @@ msgstr "必须是一个点或多点的几何体。" #: src/natcap/invest/coastal_vulnerability.py:93 #, python-format -msgid "" -"Proportion of the highest 10% of wind speeds in the record of interest " -"that blow in the direction of each sector." +msgid "Proportion of the highest 10% of wind speeds in the record of interest that blow in the direction of each sector." msgstr "在感兴趣的记录中,吹向各方向的最高10% of风速的比例。" #: src/natcap/invest/coastal_vulnerability.py:100 #, python-format -msgid "" -"Average of the highest 10% of wind speeds that blow in the direction of " -"each sector." +msgid "Average of the highest 10% of wind speeds that blow in the direction of each sector." msgstr "吹向各方向的最高10% of风速的平均值。" #: src/natcap/invest/coastal_vulnerability.py:105 #, python-format -msgid "" -"Proportion of the highest 10% of wave power values on record that are in " -"each sector." +msgid "Proportion of the highest 10% of wave power values on record that are in each sector." msgstr "每个区段的最高10% of波能的记录比例。" #: src/natcap/invest/coastal_vulnerability.py:111 #, python-format -msgid "" -"Average of the highest 10% of wave power values on record in the " -"direction of each sector." +msgid "Average of the highest 10% of wave power values on record in the direction of each sector." msgstr "每个方向上记录的最高10% of波能的平均值。" #: src/natcap/invest/coastal_vulnerability.py:116 #, python-format -msgid "" -"Average of the highest 10% of wind speeds that are centered on each main " -"sector direction X." +msgid "Average of the highest 10% of wind speeds that are centered on each main sector direction X." msgstr "以每个主要扇形方向X为中心的最高10% of风速的平均值。" #: src/natcap/invest/coastal_vulnerability.py:145 @@ -394,14 +324,11 @@ msgstr "模型分辨率" #: src/natcap/invest/coastal_vulnerability.py:159 msgid "" -"Map of all landmasses in and around the region of interest. It is not " -"recommended to clip this landmass to the AOI polygon because some " -"functions in the model require searching for landmasses around shore " -"points up to the distance defined in Maximum Fetch Distance, which likely" -" extends beyond the AOI polygon." +"Map of all landmasses in and around the region of interest. It is not recommended to clip this landmass to the AOI polygon because some functions in the model require " +"searching for landmasses around shore points up to the distance defined in Maximum Fetch Distance, which likely extends beyond the AOI polygon." msgstr "" -"兴趣区域内及其周围的所有地块的地图。不建议将该地块夹在 AOI " -"多边形中,因为模型中的一些功能需要搜索海岸点周围的地块,直到最大取样距离中定义的距离,这很可能超出了 AOI 多边形。" +"兴趣区域内及其周围的所有地块的地图。不建议将该地块夹在 AOI 多边形中,因为模型中的一些功能需要搜索海岸点周围的地块,直到最大取样距离中定义的距离,这很可能超出了 AOI 多边" +"形。" #: src/natcap/invest/coastal_vulnerability.py:166 msgid "landmasses" @@ -409,13 +336,11 @@ msgstr "陆地" #: src/natcap/invest/coastal_vulnerability.py:172 msgid "" -"Map of gridded wind and wave data that represent storm conditions. This " -"global dataset is provided with the InVEST sample data. There are 80 " -"required columns; each of the 5 types is repeated for each sixteenth " -"sector of the 360° compass: " -"[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For example:" -" REI_PCT0, V10PCT_90." -msgstr "代表风暴条件的风浪栅格数据图。这个全球数据集是与InVEST样本数据一起提供的。有80个所需的列;5种类型中的每一种都在360°罗盘的每十六个扇形区域内重复。[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337].比如说REI_PCT0,V10PCT_90。" +"Map of gridded wind and wave data that represent storm conditions. This global dataset is provided with the InVEST sample data. There are 80 required columns; each of " +"the 5 types is repeated for each sixteenth sector of the 360° compass: [0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337]. For example: REI_PCT0, V10PCT_90." +msgstr "" +"代表风暴条件的风浪栅格数据图。这个全球数据集是与InVEST样本数据一起提供的。有80个所需的列;5种类型中的每一种都在360°罗盘的每十六个扇形区域内重复。" +"[0,22,45,67,90,112,135,157,180,202,225,247,270,292,315,337].比如说REI_PCT0,V10PCT_90。" #: src/natcap/invest/coastal_vulnerability.py:180 msgid "WaveWatchIII" @@ -423,9 +348,8 @@ msgstr "波浪观察III" #: src/natcap/invest/coastal_vulnerability.py:186 msgid "" -"Maximum distance in meters to extend rays from shore points. Points with " -"rays equal to this distance accumulate ocean- driven wave exposure along " -"those rays and local-wind-driven wave exposure along the shorter rays." +"Maximum distance in meters to extend rays from shore points. Points with rays equal to this distance accumulate ocean- driven wave exposure along those rays and local-" +"wind-driven wave exposure along the shorter rays." msgstr "从海岸点延伸出的射线的最大距离(米)。射线等于这个距离的点,沿着这些射线积累海洋驱动的波浪暴露,沿着较短的射线积累局部风驱动的波浪暴露。" #: src/natcap/invest/coastal_vulnerability.py:191 @@ -434,9 +358,8 @@ msgstr "最大取水距离" #: src/natcap/invest/coastal_vulnerability.py:199 msgid "" -"Map of bathymetry (ocean depth). Bathymetry values should be negative, " -"and any positive values will be ignored. This should cover the area " -"extending beyond the AOI to the maximum fetch distance." +"Map of bathymetry (ocean depth). Bathymetry values should be negative, and any positive values will be ignored. This should cover the area extending beyond the AOI to " +"the maximum fetch distance." msgstr "水深测量(海洋深度)地图。水深值应该是负值,任何正值都将被忽略。这应涵盖AOI之外延伸到最大风速距离的区域。" #: src/natcap/invest/coastal_vulnerability.py:205 @@ -444,9 +367,7 @@ msgid "Bathymetry" msgstr "测深学" #: src/natcap/invest/coastal_vulnerability.py:211 -msgid "" -"Map of the edges of the continental shelf or other locally relevant " -"bathymetry contour." +msgid "Map of the edges of the continental shelf or other locally relevant bathymetry contour." msgstr "大陆边缘的地图或其他与当地相关的水深等值线。" #: src/natcap/invest/coastal_vulnerability.py:214 @@ -455,15 +376,12 @@ msgstr "大陆架等高线" #: src/natcap/invest/coastal_vulnerability.py:222 msgid "" -"Map of elevation above sea level on land. This should cover the area " -"extending beyond the AOI by at least the elevation averaging radius. " -"Elevation may be measured in any unit." +"Map of elevation above sea level on land. This should cover the area extending beyond the AOI by at least the elevation averaging radius. Elevation may be measured in " +"any unit." msgstr "陆地上的海平面以上地图。该图应涵盖AOI以外的区域,至少是高程平均半径的范围。高程可以用任何单位来测量。" #: src/natcap/invest/coastal_vulnerability.py:231 -msgid "" -"A radius around each shore point within which to average the elevation " -"values in the DEM raster." +msgid "A radius around each shore point within which to average the elevation values in the DEM raster." msgstr "每个海岸点的半径,在此范围内对DEM栅格中的高程值进行平均。" #: src/natcap/invest/coastal_vulnerability.py:234 @@ -476,22 +394,16 @@ msgstr "生境的独特名称。不允许有空格。" #: src/natcap/invest/coastal_vulnerability.py:247 msgid "" -"Map of area(s) where the habitat is present. If raster, presence of the " -"habitat can be represented by any value and absence of the habitat can be" -" represented by 0 and nodata values." +"Map of area(s) where the habitat is present. If raster, presence of the habitat can be represented by any value and absence of the habitat can be represented by 0 and " +"nodata values." msgstr "生境存在的区域地图。如果是栅格图,生境的存在可以用任何数值表示,生境的缺失可以用0和nodata值表示。" #: src/natcap/invest/coastal_vulnerability.py:254 -#, fuzzy -msgid "" -"Relative amount of coastline protection this habitat provides, from 1 " -"(very high protection) to 5 (very low protection." -msgstr "该生境提供的海岸线保护的相对数量。" +msgid "Relative amount of coastline protection this habitat provides, from 1 (very high protection) to 5 (very low protection." +msgstr "该生境对海岸线保护的相对程度,从 1(保护程度非常高)到 5(保护程度非常低)。" #: src/natcap/invest/coastal_vulnerability.py:263 -msgid "" -"The distance beyond which this habitat will provide no protection to the " -"coastline." +msgid "The distance beyond which this habitat will provide no protection to the coastline." msgstr "超过这个距离,这个生境就不能对海岸线提供保护。" #: src/natcap/invest/coastal_vulnerability.py:269 @@ -502,33 +414,27 @@ msgstr "指定空间生境数据和参数的表格。" msgid "habitats table" msgstr "生境表" -#: src/natcap/invest/coastal_vulnerability.py:279 -#: src/natcap/invest/coastal_vulnerability.py:416 +#: src/natcap/invest/coastal_vulnerability.py:279 src/natcap/invest/coastal_vulnerability.py:416 msgid "very low exposure" msgstr "极低暴露" -#: src/natcap/invest/coastal_vulnerability.py:280 -#: src/natcap/invest/coastal_vulnerability.py:417 +#: src/natcap/invest/coastal_vulnerability.py:280 src/natcap/invest/coastal_vulnerability.py:417 msgid "low exposure" msgstr "低暴露" -#: src/natcap/invest/coastal_vulnerability.py:281 -#: src/natcap/invest/coastal_vulnerability.py:418 +#: src/natcap/invest/coastal_vulnerability.py:281 src/natcap/invest/coastal_vulnerability.py:418 msgid "moderate exposure" msgstr "中度暴露" -#: src/natcap/invest/coastal_vulnerability.py:282 -#: src/natcap/invest/coastal_vulnerability.py:419 +#: src/natcap/invest/coastal_vulnerability.py:282 src/natcap/invest/coastal_vulnerability.py:419 msgid "high exposure" msgstr "高暴露" -#: src/natcap/invest/coastal_vulnerability.py:283 -#: src/natcap/invest/coastal_vulnerability.py:420 +#: src/natcap/invest/coastal_vulnerability.py:283 src/natcap/invest/coastal_vulnerability.py:420 msgid "very high exposure" msgstr "极高暴露" -#: src/natcap/invest/coastal_vulnerability.py:285 -#: src/natcap/invest/coastal_vulnerability.py:422 +#: src/natcap/invest/coastal_vulnerability.py:285 src/natcap/invest/coastal_vulnerability.py:422 msgid "Relative exposure of the segment of coastline." msgstr "该段海岸线的相对暴露。" @@ -561,10 +467,7 @@ msgid "5: very high exposure" msgstr "5:极高暴露" #: src/natcap/invest/coastal_vulnerability.py:303 -msgid "" -"Exposure rank to assign to any shore points that are not near to any " -"segment in the geomorphology vector. Required if a Geomorphology vector " -"is provided." +msgid "Exposure rank to assign to any shore points that are not near to any segment in the geomorphology vector. Required if a Geomorphology vector is provided." msgstr "对任何不靠近地貌向量中任何区段的海岸点进行曝光等级分配。如果提供了地貌向量则需要。" #: src/natcap/invest/coastal_vulnerability.py:307 @@ -580,9 +483,7 @@ msgid "human population" msgstr "人口" #: src/natcap/invest/coastal_vulnerability.py:323 -msgid "" -"The radius around each shore point within which to compute the average " -"population density. Required if a Human Population map is provided." +msgid "The radius around each shore point within which to compute the average population density. Required if a Human Population map is provided." msgstr "计算平均人口密度的每个海岸点周围的半径。如果提供人类人口地图,则需要。" #: src/natcap/invest/coastal_vulnerability.py:327 @@ -590,15 +491,11 @@ msgid "population search radius" msgstr "人口搜索半径" #: src/natcap/invest/coastal_vulnerability.py:333 -msgid "" -"Sea level rise rate or amount. This field name must be chosen as the Sea " -"Level Rise Field." +msgid "Sea level rise rate or amount. This field name must be chosen as the Sea Level Rise Field." msgstr "海平面上升率或数量。这个字段名必须选择为海平面上升字段。" #: src/natcap/invest/coastal_vulnerability.py:342 -msgid "" -"Map of sea level rise rates or amounts. May be any sea level rise metric " -"of interest, such as rate, or net rise/fall." +msgid "Map of sea level rise rates or amounts. May be any sea level rise metric of interest, such as rate, or net rise/fall." msgstr "海平面上升率或数量的地图。可以是任何感兴趣的海平面上升指标,如速率,或净上升/下降。" #: src/natcap/invest/coastal_vulnerability.py:345 @@ -606,10 +503,7 @@ msgid "sea level rise" msgstr "海平面上升" #: src/natcap/invest/coastal_vulnerability.py:351 -msgid "" -"Name of the field in the sea level rise vector which contains the sea " -"level rise metric of interest. Required if a Sea Level Rise vector is " -"provided." +msgid "Name of the field in the sea level rise vector which contains the sea level rise metric of interest. Required if a Sea Level Rise vector is provided." msgstr "海平面上升矢量中包含感兴趣的海平面上升指标的字段名称。如果提供了海平面上升矢量,则需要。" #: src/natcap/invest/coastal_vulnerability.py:355 @@ -617,9 +511,7 @@ msgid "sea level rise field" msgstr "海平面上升边界" #: src/natcap/invest/crop_production_percentile.py:135 -msgid "" -"A table that maps each LULC code from the LULC map to one of the 175 " -"canonical crop names representing the crop grown in that LULC class." +msgid "A table that maps each LULC code from the LULC map to one of the 175 canonical crop names representing the crop grown in that LULC class." msgstr "一个表格,将LULC地图中的每个LULC代码与代表该LULC等级中种植的175个典型的作物名称之一进行映射。" #: src/natcap/invest/crop_production_percentile.py:139 @@ -630,13 +522,11 @@ msgstr "LULC与作物对应表" msgid "Table mapping each climate bin to yield percentiles for each crop." msgstr "每个气候仓与每种作物的产量百分比的映射表。" -#: src/natcap/invest/crop_production_percentile.py:182 -#: src/natcap/invest/crop_production_regression.py:169 +#: src/natcap/invest/crop_production_percentile.py:182 src/natcap/invest/crop_production_regression.py:169 msgid "Maps of climate bins for each crop." msgstr "每种作物的气候区间图。" -#: src/natcap/invest/crop_production_percentile.py:192 -#: src/natcap/invest/crop_production_regression.py:179 +#: src/natcap/invest/crop_production_percentile.py:192 src/natcap/invest/crop_production_regression.py:179 msgid "Maps of actual observed yield for each crop." msgstr "每种作物的实际观察产量图。" @@ -685,9 +575,7 @@ msgid "wheat" msgstr "小麦" #: src/natcap/invest/crop_production_regression.py:96 -msgid "" -"A table that maps each LULC code from the LULC map to one of the 10 " -"canonical crop names representing the crop grown in that LULC class." +msgid "A table that maps each LULC code from the LULC map to one of the 10 canonical crop names representing the crop grown in that LULC class." msgstr "一个表将每个LULC代码从LULC映射到代表在该LULC类中生长的作物的10个规范作物名称中的一个。" #: src/natcap/invest/crop_production_regression.py:100 @@ -716,21 +604,19 @@ msgstr "模型数据" #: src/natcap/invest/forest_carbon_edge_effect.py:51 msgid "" -"Number of closest regression models that are used when calculating the " -"total biomass. Each local model is linearly weighted by distance such " -"that the pixel's biomass is a function of each of these points with the " -"closest point having the largest effect. Must be an integer greater than " -"0. Required if Compute Forest Edge Effects is selected." -msgstr "计算总生物量时使用的最接近的回归模型的数目。每个局部模型都按距离线性加权,这样像素的生物量是这些点的函数,最近的点具有最大的影响。必须为大于0的整数。如果选中“计算森林边缘效果”,则需要。" +"Number of closest regression models that are used when calculating the total biomass. Each local model is linearly weighted by distance such that the pixel's biomass " +"is a function of each of these points with the closest point having the largest effect. Must be an integer greater than 0. Required if Compute Forest Edge Effects is " +"selected." +msgstr "" +"计算总生物量时使用的最接近的回归模型的数目。每个局部模型都按距离线性加权,这样像素的生物量是这些点的函数,最近的点具有最大的影响。必须为大于0的整数。如果选中“计算森林边" +"缘效果”,则需要。" #: src/natcap/invest/forest_carbon_edge_effect.py:59 msgid "number of points to average" msgstr "平均分数" #: src/natcap/invest/forest_carbon_edge_effect.py:73 -msgid "" -"Enter 1 if the LULC class is tropical forest, 0 if it is not tropical " -"forest." +msgid "Enter 1 if the LULC class is tropical forest, 0 if it is not tropical forest." msgstr "如果LULC类是热带森林,则输入1,如果不是热带森林,则输入0。" #: src/natcap/invest/forest_carbon_edge_effect.py:79 @@ -738,27 +624,19 @@ msgid "Carbon density value for the aboveground carbon pool." msgstr "地上碳库的碳密度值。" #: src/natcap/invest/forest_carbon_edge_effect.py:87 -msgid "" -"Carbon density value for the belowground carbon pool. Required if " -"calculating all pools." +msgid "Carbon density value for the belowground carbon pool. Required if calculating all pools." msgstr "地下碳库的碳密度值。如果计算所有碳库,则必须。" #: src/natcap/invest/forest_carbon_edge_effect.py:95 -msgid "" -"Carbon density value for the soil carbon pool. Required if calculating " -"all pools." +msgid "Carbon density value for the soil carbon pool. Required if calculating all pools." msgstr "土壤碳库的碳密度值。如果计算所有碳库,则必须。" #: src/natcap/invest/forest_carbon_edge_effect.py:103 -msgid "" -"Carbon density value for the dead matter carbon pool. Required if " -"calculating all pools." +msgid "Carbon density value for the dead matter carbon pool. Required if calculating all pools." msgstr "枯木碳库的碳密度值。如果计算所有碳库,则必须。" #: src/natcap/invest/forest_carbon_edge_effect.py:108 -msgid "" -"A table mapping each LULC code from the LULC map to biophysical data for " -"that LULC class." +msgid "A table mapping each LULC code from the LULC map to biophysical data for that LULC class." msgstr "将每个LULC代码从LULC映射到该LULC类的生物物理数据的表。" #: src/natcap/invest/forest_carbon_edge_effect.py:124 @@ -766,9 +644,7 @@ msgid "all" msgstr "全部" #: src/natcap/invest/forest_carbon_edge_effect.py:125 -msgid "" -"Use all pools (aboveground, belowground, soil, and dead matter) in the " -"carbon pool calculation." +msgid "Use all pools (aboveground, belowground, soil, and dead matter) in the carbon pool calculation." msgstr "在碳库计算中使用所有的碳库(地上、地下、土壤和枯木)。" #: src/natcap/invest/forest_carbon_edge_effect.py:129 @@ -820,16 +696,13 @@ msgid "θ₂ parameter for the regression equation." msgstr "回归方程的θ₂参数。" #: src/natcap/invest/forest_carbon_edge_effect.py:165 -msgid "" -"θ₃ parameter for the regression equation. Used only for the asymptotic " -"model." +msgid "θ₃ parameter for the regression equation. Used only for the asymptotic model." msgstr "回归方程的θ₃参数。仅用于渐近模型。" #: src/natcap/invest/forest_carbon_edge_effect.py:171 msgid "" -"Map storing the optimal regression model for each tropical subregion and " -"the corresponding theta parameters for that regression equation. Default " -"data is provided. Required if Compute Forest Edge Effects is selected." +"Map storing the optimal regression model for each tropical subregion and the corresponding theta parameters for that regression equation. Default data is provided. " +"Required if Compute Forest Edge Effects is selected." msgstr "储存每个热带次区域的最佳回归模型和该回归方程的相应theta参数的地图。提供默认数据。如果选择 \"计算森林边缘效应 \"则需要。" #: src/natcap/invest/forest_carbon_edge_effect.py:176 @@ -837,9 +710,7 @@ msgid "global regression models" msgstr "全球回归模型" #: src/natcap/invest/forest_carbon_edge_effect.py:181 -msgid "" -"Proportion of forest edge biomass that is elemental carbon. Required if " -"Compute Forest Edge Effects is selected." +msgid "Proportion of forest edge biomass that is elemental carbon. Required if Compute Forest Edge Effects is selected." msgstr "森林边缘生物量中元素碳的比例。如果选择 \"计算森林边缘效应 \"则需要。" #: src/natcap/invest/forest_carbon_edge_effect.py:184 @@ -847,15 +718,11 @@ msgid "forest edge biomass to carbon conversion factor" msgstr "林缘生物量与碳的转换系数" #: src/natcap/invest/habitat_quality.py:21 -msgid "" -"Threats {threats} does not match any column in the sensitivity table. " -"Sensitivity columns: {column_names}" +msgid "Threats {threats} does not match any column in the sensitivity table. Sensitivity columns: {column_names}" msgstr "威胁{threats}与敏感度表中的任何列不匹配。敏感度列。{column_names}" #: src/natcap/invest/habitat_quality.py:24 -msgid "" -"A threat raster for threats: {threat_list} was not found or it could not " -"be opened by GDAL." +msgid "A threat raster for threats: {threat_list} was not found or it could not be opened by GDAL." msgstr "威胁的栅格。{threat_list}没有找到,或者它不能被GDAL打开。" #: src/natcap/invest/habitat_quality.py:27 @@ -863,9 +730,7 @@ msgid "Threat paths must be unique. Duplicates: " msgstr "威胁路径必须是唯一的。重复的: " #: src/natcap/invest/habitat_quality.py:46 -msgid "" -"Map of LULC at present. All values in this raster must have corresponding" -" entries in the Sensitivity table." +msgid "Map of LULC at present. All values in this raster must have corresponding entries in the Sensitivity table." msgstr "目前LULC的地图。该栅格中的所有数值都必须在敏感度表中有相应的条目。" #: src/natcap/invest/habitat_quality.py:49 @@ -874,9 +739,8 @@ msgstr "现状土地覆盖" #: src/natcap/invest/habitat_quality.py:55 msgid "" -"Map of LULC in a future scenario. All values in this raster must have " -"corresponding entries in the Sensitivity Table. Must use the same " -"classification scheme and codes as in the Current LULC map." +"Map of LULC in a future scenario. All values in this raster must have corresponding entries in the Sensitivity Table. Must use the same classification scheme and codes " +"as in the Current LULC map." msgstr "未来情景下的LULC地图。该栅格中的所有数值必须在敏感度表中有相应的条目。必须使用与当前LULC地图中相同的分类方案和代码。" #: src/natcap/invest/habitat_quality.py:60 @@ -885,10 +749,8 @@ msgstr "未来土地覆盖" #: src/natcap/invest/habitat_quality.py:66 msgid "" -"Map of LULC in a baseline scenario, when intensive landscape management " -"was relatively rare. All values in this raster must have corresponding " -"entries in the Sensitivity table. Must use the same classification scheme" -" and codes as in the Current LULC map." +"Map of LULC in a baseline scenario, when intensive landscape management was relatively rare. All values in this raster must have corresponding entries in the " +"Sensitivity table. Must use the same classification scheme and codes as in the Current LULC map." msgstr "基线情景下的LULC地图,当时密集的景观管理相对罕见。该栅格中的所有数值必须在敏感度表中有相应的条目。必须使用与当前LULC地图中相同的分类方案和代码。" #: src/natcap/invest/habitat_quality.py:72 @@ -896,17 +758,13 @@ msgid "baseline land cover" msgstr "基线土地覆盖" #: src/natcap/invest/habitat_quality.py:80 -msgid "" -"Name of the threat. Each threat name must have a corresponding column in " -"the Sensitivity table." +msgid "Name of the threat. Each threat name must have a corresponding column in the Sensitivity table." msgstr "威胁的名称。每个威胁名称必须在敏感度表中有一个相应的列。" #: src/natcap/invest/habitat_quality.py:86 msgid "" -"The maximum distance over which each threat affects habitat quality. The " -"impact of each degradation source will decline to zero at this maximum " -"distance. This value must be greater than or equal to the pixel size of " -"your LULC raster(s)." +"The maximum distance over which each threat affects habitat quality. The impact of each degradation source will decline to zero at this maximum distance. This value " +"must be greater than or equal to the pixel size of your LULC raster(s)." msgstr "每个威胁影响生境质量的最大距离。每个退化源的影响在这个最大距离上会下降到零。这个值必须大于或等于你的LULC栅格的像素大小。" #: src/natcap/invest/habitat_quality.py:95 @@ -926,34 +784,25 @@ msgid "The type of decay over space for each threat." msgstr "每种威胁在空间上的衰减类型。" #: src/natcap/invest/habitat_quality.py:116 -#, fuzzy msgid "" -"Path to a raster of the threat's distribution in the current scenario. " -"Each pixel value in this raster is the relative intensity of the threat " -"at that location, with values between 0 and 1." -msgstr "当前场景下的威胁分布图。每个像素值都是该位置威胁的相对强度。 " +"Path to a raster of the threat's distribution in the current scenario. Each pixel value in this raster is the relative intensity of the threat at that location, with " +"values between 0 and 1." +msgstr "当前场景中威胁分布的栅格路径。栅格中的每个像素值都是该位置威胁的相对强度,数值介于 0 和 1 之间。" #: src/natcap/invest/habitat_quality.py:127 -#, fuzzy msgid "" -"Path to a raster of the threat's distribution in a future scenario. Each " -"pixel value in this raster is the relative intensity of the threat at " -"that location, with values between 0 and 1." -msgstr "当前场景下的威胁分布图。每个像素值都是该位置威胁的相对强度。 " +"Path to a raster of the threat's distribution in a future scenario. Each pixel value in this raster is the relative intensity of the threat at that location, with " +"values between 0 and 1." +msgstr "未来场景中威胁分布的栅格路径。栅格中的每个像素值都是该位置威胁的相对强度,数值介于 0 和 1 之间。" #: src/natcap/invest/habitat_quality.py:138 -#, fuzzy msgid "" -"Path to a raster of the threat's distribution in the baseline scenario. " -"Each pixel value in this raster is the relative intensity of the threat " -"at that location, with values between 0 and 1. Required if Baseline LULC " -"is provided." -msgstr "基线场景中威胁分布的地图。每个像素值都是该位置威胁的相对强度。如果提供了基线LULC,则需要。" +"Path to a raster of the threat's distribution in the baseline scenario. Each pixel value in this raster is the relative intensity of the threat at that location, with " +"values between 0 and 1. Required if Baseline LULC is provided." +msgstr "在基准情景下,威胁分布的栅格路径。该栅格中的每个像素值代表该位置的威胁相对强度,取值介于0和1之间。如果提供基准土地利用/土地覆盖数据,则此项为必填项。" #: src/natcap/invest/habitat_quality.py:146 -msgid "" -"Table mapping each threat of interest to its properties and distribution " -"maps. Paths are relative to the threats table path." +msgid "Table mapping each threat of interest to its properties and distribution maps. Paths are relative to the threats table path." msgstr "表将每个感兴趣威胁的属性和映射。路径相对于威胁表路径。" #: src/natcap/invest/habitat_quality.py:150 @@ -961,16 +810,12 @@ msgid "threats table" msgstr "威胁表格" #: src/natcap/invest/habitat_quality.py:158 -msgid "" -"The region's relative accessibility to threats, where 0 represents " -"completely inaccessible and 1 represents completely accessible." +msgid "The region's relative accessibility to threats, where 0 represents completely inaccessible and 1 represents completely accessible." msgstr "该区域对威胁的相对可达性,其中0表示完全不可达,1表示完全可达。" #: src/natcap/invest/habitat_quality.py:166 msgid "" -"Map of the relative protection that legal, institutional, social, and " -"physical barriers provide against threats. Any cells not covered by a " -"polygon will be set to 1." +"Map of the relative protection that legal, institutional, social, and physical barriers provide against threats. Any cells not covered by a polygon will be set to 1." msgstr "法律、制度、社会和物理障碍对威胁的相对保护。任何未被多边形覆盖的单元格将被设置为1。" #: src/natcap/invest/habitat_quality.py:170 @@ -978,23 +823,17 @@ msgid "accessibility to threats" msgstr "威胁的可达性" #: src/natcap/invest/habitat_quality.py:183 -msgid "" -"Suitability of this LULC class as habitat, where 0 is not suitable and 1 " -"is completely suitable." +msgid "Suitability of this LULC class as habitat, where 0 is not suitable and 1 is completely suitable." msgstr "该LULC类生境的适宜性,0为不适宜,1为完全适宜。" #: src/natcap/invest/habitat_quality.py:189 msgid "" -"The relative sensitivity of each LULC class to each type of threat, where" -" 1 represents high sensitivity and 0 represents that it is unaffected. " -"There must be one threat column for each threat name in the 'threats' " -"column of the Threats Table." +"The relative sensitivity of each LULC class to each type of threat, where 1 represents high sensitivity and 0 represents that it is unaffected. There must be one " +"threat column for each threat name in the 'threats' column of the Threats Table." msgstr "每个LULC类对每种威胁类型的相对敏感性,其中1表示高敏感性,0表示不受影响。在“威胁表”的“威胁”列中,每个威胁必须有一个对应列。" #: src/natcap/invest/habitat_quality.py:197 -msgid "" -"Table mapping each LULC class to data about the species' habitat " -"preference and threat sensitivity in areas with that LULC." +msgid "Table mapping each LULC class to data about the species' habitat preference and threat sensitivity in areas with that LULC." msgstr "将每个LULC类映射到具有该LULC区域的物种栖息地偏好和威胁敏感性的数据。" #: src/natcap/invest/habitat_quality.py:201 @@ -1018,23 +857,17 @@ msgid "A table describing each habitat and stressor." msgstr "描述每个生境和压力源的表格。" #: src/natcap/invest/hra.py:68 -msgid "" -"A unique name for each habitat or stressor. These names must match the " -"habitat and stressor names in the Criteria Scores Table." +msgid "A unique name for each habitat or stressor. These names must match the habitat and stressor names in the Criteria Scores Table." msgstr "每个生境或压力源的唯一名称。这些名称必须符合标准评分表中的生境和压力源名称。" #: src/natcap/invest/hra.py:77 -msgid "" -"Pixel values are 1, indicating presence of the habitat/stressor, or 0 " -"indicating absence. Any values besides 0 or 1 will be treated as 0." +msgid "Pixel values are 1, indicating presence of the habitat/stressor, or 0 indicating absence. Any values besides 0 or 1 will be treated as 0." msgstr "栅格值为1,表示生境/压力源存在,或0表示不存在。除0或1以外的任何值都将被视为0。" #: src/natcap/invest/hra.py:84 msgid "" -"Map of where the habitat or stressor exists. For rasters, a pixel value " -"of 1 indicates presence of the habitat or stressor. 0 (or any other " -"value) indicates absence of the habitat or stressor. For vectors, a " -"polygon indicates an area where the habitat or stressor is present." +"Map of where the habitat or stressor exists. For rasters, a pixel value of 1 indicates presence of the habitat or stressor. 0 (or any other value) indicates absence of " +"the habitat or stressor. For vectors, a polygon indicates an area where the habitat or stressor is present." msgstr "生境或压力源的分布图。对于栅格,值为1表示生境或压力源的存在。0(或任何其他值)表示没有生境或压力源。对于矢量,多边形表示生境或压力源存在的区域。" #: src/natcap/invest/hra.py:95 @@ -1051,15 +884,12 @@ msgstr "不管这是用作生境还是用作压力源。" #: src/natcap/invest/hra.py:104 msgid "" -"The desired buffer distance used to expand a given stressor’s influence " -"or footprint. This should be left blank for habitats, but must be filled " -"in for stressors. Enter 0 if no buffering is desired for a given " -"stressor. The model will round down this buffer distance to the nearest " -"cell unit. e.g., a buffer distance of 600m will buffer a stressor’s " -"footprint by two grid cells if the resolution of analysis is 250m." +"The desired buffer distance used to expand a given stressor’s influence or footprint. This should be left blank for habitats, but must be filled in for stressors. " +"Enter 0 if no buffering is desired for a given stressor. The model will round down this buffer distance to the nearest cell unit. e.g., a buffer distance of 600m will " +"buffer a stressor’s footprint by two grid cells if the resolution of analysis is 250m." msgstr "" -"用于扩大给定压力源的影响或影响范围的所需缓冲距离。这里应该为生境留下空白,但必须为压力源填写。如果给定的压力源不需要缓冲,则输入0。模型将把这个缓冲距离舍入到最近的栅格单元。例如,如果分析分辨率为250m," -" 600m的缓冲距离将用两个栅格单元缓冲压力源的足迹。" +"用于扩大给定压力源的影响或影响范围的所需缓冲距离。这里应该为生境留下空白,但必须为压力源填写。如果给定的压力源不需要缓冲,则输入0。模型将把这个缓冲距离舍入到最近的栅格" +"单元。例如,如果分析分辨率为250m, 600m的缓冲距离将用两个栅格单元缓冲压力源的足迹。" #: src/natcap/invest/hra.py:118 msgid "criteria scores table" @@ -1074,9 +904,7 @@ msgid "resolution of analysis" msgstr "分析的决议" #: src/natcap/invest/hra.py:125 -msgid "" -"The resolution at which to run the analysis. The model outputs will have " -"this resolution." +msgid "The resolution at which to run the analysis. The model outputs will have this resolution." msgstr "运行分析的分辨率。模型将输出这个分辨率。" #: src/natcap/invest/hra.py:133 @@ -1124,9 +952,7 @@ msgid "Linear" msgstr "线性" #: src/natcap/invest/hra.py:164 -msgid "" -"Stressor effects in the buffer area decay linearly with distance from the" -" stressor." +msgid "Stressor effects in the buffer area decay linearly with distance from the stressor." msgstr "缓冲区内的压力源效应随着与压力源的距离线性衰减。" #: src/natcap/invest/hra.py:168 @@ -1134,21 +960,15 @@ msgid "Exponential" msgstr "指数型" #: src/natcap/invest/hra.py:169 -msgid "" -"Stressor effects in the buffer area decay exponentially with distance " -"from the stressor." +msgid "Stressor effects in the buffer area decay exponentially with distance from the stressor." msgstr "缓冲区内的压迫物效应随着与压迫物的距离呈指数级衰减。" #: src/natcap/invest/hra.py:182 -msgid "" -"Uniquely identifies each feature. Required if the vector contains more " -"than one feature." +msgid "Uniquely identifies each feature. Required if the vector contains more than one feature." msgstr "独特地识别每个特征。如果向量包含一个以上的特征,则需要。" #: src/natcap/invest/hra.py:187 -msgid "" -"A GDAL-supported vector file containing features representing one or more" -" planning regions or subregions." +msgid "A GDAL-supported vector file containing features representing one or more planning regions or subregions." msgstr "一个GDAL支持的矢量文件,包含代表一个或多个规划区域或次区域的特征。" #: src/natcap/invest/hra.py:192 @@ -1157,9 +977,7 @@ msgstr "重叠的压力源的数量" #: src/natcap/invest/hra.py:195 msgid "" -"The number of overlapping stressors to consider as 'maximum' when " -"reclassifying risk scores into high/medium/low. Affects the breaks " -"between risk classifications." +"The number of overlapping stressors to consider as 'maximum' when reclassifying risk scores into high/medium/low. Affects the breaks between risk classifications." msgstr "在将风险分数重新分类为高/中/低时,将重叠的压力源的数量视为 \"最大\"。 影响到风险分类之间的断裂。" #: src/natcap/invest/hra.py:204 @@ -1268,34 +1086,26 @@ msgstr "城市降温" #: src/natcap/invest/model_metadata.py:162 msgid "Urban Nature Access" -msgstr "" +msgstr "城市自然接触" #: src/natcap/invest/pollination.py:37 -msgid "" -"Map of LULC codes. All values in this raster must have corresponding " -"entries in the Biophysical Table." +msgid "Map of LULC codes. All values in this raster must have corresponding entries in the Biophysical Table." msgstr "LULC代码的地图。该栅格中的所有数值必须在生物物理表中有相应的条目。" #: src/natcap/invest/pollination.py:47 -msgid "" -"Unique name or identifier for each pollinator species or guild of " -"interest." +msgid "Unique name or identifier for each pollinator species or guild of interest." msgstr "每个传粉者物种的唯一名称或标识符。" #: src/natcap/invest/pollination.py:53 msgid "" -"Utilization of the substrate by this species, where 1 indicates the " -"nesting substrate is fully utilized and 0 indicates it is not utilized at" -" all. Replace [SUBSTRATE] with substrate names matching those in the " -"Biophysical Table, so that there is a column for each substrate." +"Utilization of the substrate by this species, where 1 indicates the nesting substrate is fully utilized and 0 indicates it is not utilized at all. Replace [SUBSTRATE] " +"with substrate names matching those in the Biophysical Table, so that there is a column for each substrate." msgstr "该物种对基质的利用情况,其中1表示筑巢基质被充分利用,0表示完全没有利用。用生物物理表中匹配的底物名称替换[SUBSTRATE],这样每个底物都有一个列。" #: src/natcap/invest/pollination.py:63 msgid "" -"Pollinator activity for this species/guild in each season. 1 indicates " -"maximum activity for the species/guild, and 0 indicates no activity. " -"Replace [SEASON] with season names matching those in the biophysical " -"table, so that there is a column for each season." +"Pollinator activity for this species/guild in each season. 1 indicates maximum activity for the species/guild, and 0 indicates no activity. Replace [SEASON] with " +"season names matching those in the biophysical table, so that there is a column for each season." msgstr "本物种/公会在每个季节的传粉者活动。1表示该物种/公会的最大活动,0表示没有活动。用生物物理表中匹配的季节名替换[SEASON],这样每个季节都有一个列。" #: src/natcap/invest/pollination.py:74 @@ -1303,15 +1113,11 @@ msgid "Average distance that this species or guild travels to forage on flowers. msgstr "这个物种或公会在花上觅食的平均距离。" #: src/natcap/invest/pollination.py:80 -msgid "" -"The proportion of total pollinator abundance that consists of this " -"species/guild." +msgid "The proportion of total pollinator abundance that consists of this species/guild." msgstr "由该物种/协会组成的传粉者总数的比例。" #: src/natcap/invest/pollination.py:85 -msgid "" -"A table mapping each pollinator species or guild of interest to its " -"pollination-related parameters." +msgid "A table mapping each pollinator species or guild of interest to its pollination-related parameters." msgstr "一个表,将每一个传粉者物种或感兴趣的协会的传粉相关参数。" #: src/natcap/invest/pollination.py:88 @@ -1320,60 +1126,47 @@ msgstr "公会表" #: src/natcap/invest/pollination.py:97 msgid "" -"Index of availability of the given substrate in this LULC class. Replace " -"[SUBSTRATE] with substrate names matching those in the Guild Table, so " -"that there is a column for each substrate." +"Index of availability of the given substrate in this LULC class. Replace [SUBSTRATE] with substrate names matching those in the Guild Table, so that there is a column " +"for each substrate." msgstr "该LULC类中给定基质的可用性索引。用与公会表中的基质名称相匹配的基质名称替换[SUBSTRATE],这样,每个基质都有一列。" #: src/natcap/invest/pollination.py:104 msgid "" -"Abundance of flowers during the given season in this LULC class. This is " -"the proportion of land area covered by flowers, multiplied by the " -"proportion of the season for which there is that coverage. Replace " -"[SEASON] with season names matching those in the Guild Table, so that " -"there is a column for each season." -msgstr "该LULC等级在特定季节的花卉丰度。这是花卉覆盖的土地面积的比例,乘以有该覆盖的季节的比例。用与公会表中的季节名称相匹配的季节名称替换[SEASON],以便每个季节都有一列。" +"Abundance of flowers during the given season in this LULC class. This is the proportion of land area covered by flowers, multiplied by the proportion of the season for " +"which there is that coverage. Replace [SEASON] with season names matching those in the Guild Table, so that there is a column for each season." +msgstr "" +"该LULC等级在特定季节的花卉丰度。这是花卉覆盖的土地面积的比例,乘以有该覆盖的季节的比例。用与公会表中的季节名称相匹配的季节名称替换[SEASON],以便每个季节都有一列。" #: src/natcap/invest/pollination.py:113 msgid "" -"A table mapping each LULC class to nesting availability and floral " -"abundance data for each substrate and season in that LULC class. All " -"values in the LULC raster must have corresponding entries in this table." +"A table mapping each LULC class to nesting availability and floral abundance data for each substrate and season in that LULC class. All values in the LULC raster must " +"have corresponding entries in this table." msgstr "一个将每个LULC等级与该LULC等级中每个基质和季节的筑巢可用性和花卉丰度数据进行映射的表格。LULC栅格中的所有数值必须在此表中有相应的条目。" #: src/natcap/invest/pollination.py:125 -msgid "" -"Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', " -"etc." +msgid "Name of the crop grown on each polygon, e.g. 'blueberries', 'almonds', etc." msgstr "每个多边形上种植的作物名称,如 \"蓝莓\"、\"杏仁 \"等。" #: src/natcap/invest/pollination.py:130 msgid "" -"The half saturation coefficient for the crop grown in this area. This is " -"the wild pollinator abundance (i.e. the proportion of all pollinators " -"that are wild) needed to reach half of the total potential pollinator-" -"dependent yield." +"The half saturation coefficient for the crop grown in this area. This is the wild pollinator abundance (i.e. the proportion of all pollinators that are wild) needed to " +"reach half of the total potential pollinator-dependent yield." msgstr "该地区种植的作物的半饱和系数。这是达到依赖授粉者的潜在总产量的一半所需的野生授粉者丰度(即所有授粉者中野生的比例)。" #: src/natcap/invest/pollination.py:138 -msgid "" -"The season in which the crop is pollinated. Season names must match those" -" in the Guild Table and Biophysical Table." +msgid "The season in which the crop is pollinated. Season names must match those in the Guild Table and Biophysical Table." msgstr "作物授粉的季节。季节名称必须与公会表和生物物理表中的名称一致。" #: src/natcap/invest/pollination.py:144 msgid "" -"The floral resources available at this farm for the given season. Replace" -" [SEASON] with season names matching those in the Guild Table and " -"Biophysical Table, so that there is one field for each season." +"The floral resources available at this farm for the given season. Replace [SEASON] with season names matching those in the Guild Table and Biophysical Table, so that " +"there is one field for each season." msgstr "这个农场在给定季节可获得的花草资源。用与行会表和生物物理表相匹配的季节名称替换[SEASON],这样每个季节就有一个字段。" #: src/natcap/invest/pollination.py:152 msgid "" -"The nesting suitability for the given substrate at this farm. given " -"substrate. Replace [SUBSTRATE] with substrate names matching those in the" -" Guild Table and Biophysical Table, so that there is one field for each " -"substrate." +"The nesting suitability for the given substrate at this farm. given substrate. Replace [SUBSTRATE] with substrate names matching those in the Guild Table and " +"Biophysical Table, so that there is one field for each substrate." msgstr "该农场对给定基质的嵌套适用性。 给定基质。用与公会表和生物物理表中的基质名称相匹配的基质名称替换[SUBSTRATE],这样每个基质就有一个字段。" #: src/natcap/invest/pollination.py:160 @@ -1381,15 +1174,11 @@ msgid "The proportion of crop dependent on pollinators." msgstr "依靠传粉者的作物比例。" #: src/natcap/invest/pollination.py:165 -msgid "" -"The proportion of pollination required on the farm that is provided by " -"managed pollinators." +msgid "The proportion of pollination required on the farm that is provided by managed pollinators." msgstr "农场中由管理传粉者提供的传粉比例。" #: src/natcap/invest/pollination.py:171 -msgid "" -"Map of farm sites to be analyzed, with pollination data specific to each " -"farm." +msgid "Map of farm sites to be analyzed, with pollination data specific to each farm." msgstr "要分析的农场地点的地图,每个农场的授粉数据。" #: src/natcap/invest/pollination.py:174 @@ -1398,42 +1187,33 @@ msgstr "农场地图" #: src/natcap/invest/pollination.py:180 msgid "A copy of the input farm polygon vector file with additional fields" -msgstr "" +msgstr "带有附加字段的输入农场多边形矢量文件的副本" #: src/natcap/invest/pollination.py:212 -msgid "" -"Total pollinator abundance across all species per season, clipped to the " -"geometry of the farm vector’s polygons." -msgstr "" +msgid "Total pollinator abundance across all species per season, clipped to the geometry of the farm vector’s polygons." +msgstr "每个季节所有物种的传粉媒介总量,裁剪到农场矢量多边形的几何形状。" #: src/natcap/invest/pollination.py:218 msgid "Abundance of pollinator SPECIES in season SEASON." -msgstr "" +msgstr "季节SEASON中传粉媒介物种的丰富度。" #: src/natcap/invest/pollination.py:222 msgid "" -"Index of pollinator SPECIES that could be on a pixel given its arbitrary " -"abundance factor from the table, multiplied by the habitat suitability " -"for that species at that pixel, multiplied by the available floral " -"resources that a pollinator could fly to from that pixel." -msgstr "" +"Index of pollinator SPECIES that could be on a pixel given its arbitrary abundance factor from the table, multiplied by the habitat suitability for that species at " +"that pixel, multiplied by the available floral resources that a pollinator could fly to from that pixel." +msgstr "根据表中任意丰富度因子,乘以该像素处该物种的栖息地适宜性,再乘以传粉媒介从该像素飞往的可用花卉资源,得出可能在该像素上的传粉媒介物种指数。" #: src/natcap/invest/pollination.py:232 -#, fuzzy msgid "Total pollinator abundance across all species per season." -msgstr "由该物种/协会组成的传粉者总数的比例。" +msgstr "每个季节所有物种的授粉者总丰度。" #: src/natcap/invest/pollination.py:238 -msgid "" -"Total pollinator yield index for pixels that overlap farms, including " -"wild and managed pollinators." -msgstr "" +msgid "Total pollinator yield index for pixels that overlap farms, including wild and managed pollinators." +msgstr "重叠农场的像素的总传粉媒介产量指数,包括野生和人工管理的传粉媒介。" #: src/natcap/invest/pollination.py:245 -msgid "" -"Pollinator yield index for pixels that overlap farms, for wild " -"pollinators only." -msgstr "" +msgid "Pollinator yield index for pixels that overlap farms, for wild pollinators only." +msgstr "仅包括野生传粉媒介的重叠农场像素的传粉媒介产量指数。" #: src/natcap/invest/routedem.py:18 msgid "Must be between 1 and {maximum}" @@ -1448,15 +1228,11 @@ msgid "band index" msgstr "波段索引" #: src/natcap/invest/routedem.py:43 -msgid "" -"All water on a pixel flows into the most downhill of its 8 surrounding " -"pixels" +msgid "All water on a pixel flows into the most downhill of its 8 surrounding pixels" msgstr "一个栅格上的所有水都流入周围8个栅格中最下坡的一个" #: src/natcap/invest/routedem.py:48 -msgid "" -"Flow off a pixel is modeled fractionally so that water is split among " -"multiple downslope pixels" +msgid "Flow off a pixel is modeled fractionally so that water is split among multiple downslope pixels" msgstr "一个栅格的流量是分段建模的,因此水在多个下斜坡栅格之间被分割" #: src/natcap/invest/routedem.py:52 @@ -1496,9 +1272,7 @@ msgid "Required if Calculate Streams is selected." msgstr "如果选中“计算流”,则需要。" #: src/natcap/invest/routedem.py:85 -msgid "" -"Calculate flow distance from each pixel to a stream as defined in the " -"Calculate Streams output." +msgid "Calculate flow distance from each pixel to a stream as defined in the Calculate Streams output." msgstr "计算从每个栅格到在计算流输出中定义的流的距离。" #: src/natcap/invest/routedem.py:88 @@ -1514,28 +1288,23 @@ msgid "calculate slope" msgstr "计算坡度" #: src/natcap/invest/routedem.py:99 -#, fuzzy msgid "Calculate the Strahler Stream order." -msgstr "计算到溪流的距离" +msgstr "计算斯特拉勒河流级数。" #: src/natcap/invest/routedem.py:100 -#, fuzzy msgid "calculate strahler stream orders (D8 only)" -msgstr "计算到溪流的距离" +msgstr "计算斯特拉勒河流级数(仅限D8)。" #: src/natcap/invest/routedem.py:105 msgid "Determine subwatersheds from the stream order." -msgstr "" +msgstr "根据河流级数确定子流域。" #: src/natcap/invest/routedem.py:106 -#, fuzzy msgid "calculate subwatersheds (D8 only)" -msgstr "计算流" +msgstr "计算子流域(仅 D8)。" #: src/natcap/invest/scenario_gen_proximity.py:28 -msgid "" -"One or more of \"convert_nearest_to_edge\" or " -"\"convert_farthest_from_edge\" must be selected" +msgid "One or more of \"convert_nearest_to_edge\" or \"convert_farthest_from_edge\" must be selected" msgstr "必须选择“convert_nearest_to_edge”或“convert_farthest_from_edge”中的一个或多个" #: src/natcap/invest/scenario_gen_proximity.py:43 @@ -1563,10 +1332,7 @@ msgid "maximum area to convert" msgstr "可转换的最大面积" #: src/natcap/invest/scenario_gen_proximity.py:61 -msgid "" -"A space-separated list of LULC codes that are used to determine the " -"proximity when referring to 'towards' or 'away' from the base landcover " -"codes" +msgid "A space-separated list of LULC codes that are used to determine the proximity when referring to 'towards' or 'away' from the base landcover codes" msgstr "一个以空格分隔的LULC代码列表,用于在提到“朝向”或“远离”基本地表覆盖代码时确定邻近性" #: src/natcap/invest/scenario_gen_proximity.py:65 @@ -1574,9 +1340,7 @@ msgid "focal landcover codes" msgstr "焦点土地覆盖代码" #: src/natcap/invest/scenario_gen_proximity.py:70 -msgid "" -"A space-separated list of LULC codes that can be converted to be " -"converted to agriculture." +msgid "A space-separated list of LULC codes that can be converted to be converted to agriculture." msgstr "一个用空格分隔的LULC代码列表,可以转换为农业代码。" #: src/natcap/invest/scenario_gen_proximity.py:73 @@ -1585,28 +1349,23 @@ msgstr "可转换的土地覆盖代码" #: src/natcap/invest/scenario_gen_proximity.py:79 msgid "" -"The number of steps that the simulation should take to fragment the " -"habitat of interest in the fragmentation scenario. This parameter is used" -" to divide the conversion simulation into equal subareas of the requested" -" max area. During each sub-step the distance transform is recalculated " -"from the base landcover codes. This can affect the final result if the " -"base types are also convertible types." -msgstr "在碎片场景中,模拟将感兴趣的栖息地碎片化所应采取的步骤数。此参数用于将转换模拟划分为所请求的最大区域的相等子区域。在每一个子步骤中,从基本的土地覆盖编码重新计算距离变换。如果基类型也是可转换类型,这可能会影响最终结果。" +"The number of steps that the simulation should take to fragment the habitat of interest in the fragmentation scenario. This parameter is used to divide the conversion " +"simulation into equal subareas of the requested max area. During each sub-step the distance transform is recalculated from the base landcover codes. This can affect " +"the final result if the base types are also convertible types." +msgstr "" +"在碎片场景中,模拟将感兴趣的栖息地碎片化所应采取的步骤数。此参数用于将转换模拟划分为所请求的最大区域的相等子区域。在每一个子步骤中,从基本的土地覆盖编码重新计算距离变" +"换。如果基类型也是可转换类型,这可能会影响最终结果。" #: src/natcap/invest/scenario_gen_proximity.py:87 msgid "number of conversion steps" msgstr "转换步骤数量" #: src/natcap/invest/scenario_gen_proximity.py:92 -msgid "" -"Area over which to run the conversion. Provide this input if change is " -"only desired in a subregion of the Base LULC map." +msgid "Area over which to run the conversion. Provide this input if change is only desired in a subregion of the Base LULC map." msgstr "运行转换的区域。如果只希望在Base LULC映射的子区域中进行更改,则提供此输入。" #: src/natcap/invest/scenario_gen_proximity.py:98 -msgid "" -"Convert the 'convertible' landcover codes starting at the furthest pixel " -"from the 'focal' land cover areas and working inwards." +msgid "Convert the 'convertible' landcover codes starting at the furthest pixel from the 'focal' land cover areas and working inwards." msgstr "从距离“焦点”土地覆盖区域最远的像素开始,向内转换“可转换”土地覆盖代码。" #: src/natcap/invest/scenario_gen_proximity.py:102 @@ -1614,9 +1373,7 @@ msgid "convert farthest from edge" msgstr "从最远的边开始转换" #: src/natcap/invest/scenario_gen_proximity.py:106 -msgid "" -"Convert the 'convertible' landcover codes starting at the nearest pixels " -"to the 'focal' land cover areas and working outwards." +msgid "Convert the 'convertible' landcover codes starting at the nearest pixels to the 'focal' land cover areas and working outwards." msgstr "将“可转换”土地覆盖代码从最近的像素开始转换为“焦点”土地覆盖区域并向外工作。" #: src/natcap/invest/scenario_gen_proximity.py:110 @@ -1625,34 +1382,27 @@ msgstr "最接近边的转换" #: src/natcap/invest/scenario_gen_proximity.py:115 msgid "Map of the nearest-to-edge conversion scenario." -msgstr "" +msgstr "最接近边缘转换方案的地图。" #: src/natcap/invest/scenario_gen_proximity.py:119 msgid "Map of the farthest-from-edge conversion scenario." -msgstr "" +msgstr "最远离边缘转换方案的地图。" -#: src/natcap/invest/scenario_gen_proximity.py:123 -#: src/natcap/invest/scenario_gen_proximity.py:143 -msgid "" -"Table of land cover classes and the amount of each that was converted for" -" the nearest-to-edge conversion scenario." -msgstr "" +#: src/natcap/invest/scenario_gen_proximity.py:123 src/natcap/invest/scenario_gen_proximity.py:143 +msgid "Table of land cover classes and the amount of each that was converted for the nearest-to-edge conversion scenario." +msgstr "最接近边缘转换方案中每种土地覆盖类别及其转换量的表格。" #: src/natcap/invest/scenario_gen_proximity.py:166 msgid "Copy of the LULC raster masked to the AOI extent." -msgstr "" +msgstr "LULC栅格数据掩蔽到AOI范围的副本。" #: src/natcap/invest/scenario_gen_proximity.py:171 -msgid "" -"Map of the distance from each pixel to the farthest edge of the focal " -"landcover." -msgstr "" +msgid "Map of the distance from each pixel to the farthest edge of the focal landcover." +msgstr "到焦点土地覆盖物最远边缘的每个像素的距离地图。" #: src/natcap/invest/scenario_gen_proximity.py:177 -msgid "" -"Map of the distance from each pixel to the nearest edge of the focal " -"landcover." -msgstr "" +msgid "Map of the distance from each pixel to the nearest edge of the focal landcover." +msgstr "到焦点土地覆盖物最近边缘的每个像素的距离地图。" #: src/natcap/invest/spec_utils.py:12 msgid "workspace" @@ -1660,9 +1410,8 @@ msgstr "工作空间" #: src/natcap/invest/spec_utils.py:13 msgid "" -"The folder where all the model's output files will be written. If this " -"folder does not exist, it will be created. If data already exists in the " -"folder, it will be overwritten." +"The folder where all the model's output files will be written. If this folder does not exist, it will be created. If data already exists in the folder, it will be " +"overwritten." msgstr "将写入所有模型输出文件的文件夹。如果这个文件夹不存在,将创建它。如果数据已经存在于文件夹中,它将被覆盖。" #: src/natcap/invest/spec_utils.py:24 @@ -1670,9 +1419,7 @@ msgid "file suffix" msgstr "文件后缀" #: src/natcap/invest/spec_utils.py:25 -msgid "" -"Suffix that will be appended to all output file names. Useful to " -"differentiate between model runs." +msgid "Suffix that will be appended to all output file names. Useful to differentiate between model runs." msgstr "后缀,它将附加到所有输出文件名。区分模型运行很有用。" #: src/natcap/invest/spec_utils.py:34 @@ -1681,10 +1428,8 @@ msgstr "任务图n_workers参数" #: src/natcap/invest/spec_utils.py:35 msgid "" -"The n_workers parameter to provide to taskgraph. -1 will cause all jobs " -"to run synchronously. 0 will run all jobs in the same process, but " -"scheduling will take place asynchronously. Any other positive integer " -"will cause that many processes to be spawned to execute tasks." +"The n_workers parameter to provide to taskgraph. -1 will cause all jobs to run synchronously. 0 will run all jobs in the same process, but scheduling will take place " +"asynchronously. Any other positive integer will cause that many processes to be spawned to execute tasks." msgstr "提供给任务图的n_workers参数。-1将使所有作业同步运行。0将运行同一进程中的所有作业,但调度将异步进行。任何其他正整数都将导致生成同样多的进程来执行任务。" #: src/natcap/invest/spec_utils.py:60 @@ -1696,9 +1441,7 @@ msgid "A map of areas over which to aggregate and summarize the final results." msgstr "汇总和总结最终结果的区域地图。" #: src/natcap/invest/spec_utils.py:68 -msgid "" -"Map of land use/land cover codes. Each land use/land cover type must be " -"assigned a unique integer code." +msgid "Map of land use/land cover codes. Each land use/land cover type must be assigned a unique integer code." msgstr "土地利用/土地覆盖代码栅格地图。 每种土地利用/土地覆盖类型必须用一个唯一的整数代码来表示。" #: src/natcap/invest/spec_utils.py:71 @@ -1730,9 +1473,7 @@ msgid "Map of evapotranspiration values." msgstr "蒸发量值地图。" #: src/natcap/invest/spec_utils.py:109 -msgid "" -"Map of soil hydrologic groups. Pixels may have values 1, 2, 3, or 4, " -"corresponding to soil hydrologic groups A, B, C, or D, respectively." +msgid "Map of soil hydrologic groups. Pixels may have values 1, 2, 3, or 4, corresponding to soil hydrologic groups A, B, C, or D, respectively." msgstr "土壤水文组的地图。栅格的值可以是1、2、3或4,分别对应于土壤水文组A、B、C或D。" #: src/natcap/invest/spec_utils.py:112 @@ -1740,60 +1481,48 @@ msgid "soil hydrologic group" msgstr "土壤水文组" #: src/natcap/invest/spec_utils.py:118 -msgid "" -"The number of upslope pixels that must flow into a pixel before it is " -"classified as a stream." +msgid "The number of upslope pixels that must flow into a pixel before it is classified as a stream." msgstr "在被归类为流之前,必须流入一个栅格的上坡栅格的数量。" #: src/natcap/invest/spec_utils.py:121 msgid "threshold flow accumulation" msgstr "阈值流量累积" -#: src/natcap/invest/spec_utils.py:125 -#: src/natcap/invest/urban_flood_risk_mitigation.py:64 -#, fuzzy +#: src/natcap/invest/spec_utils.py:125 src/natcap/invest/urban_flood_risk_mitigation.py:64 msgid "LULC codes from the LULC raster. Each code must be a unique integer." -msgstr "来自 LULC 栅格的 LULC 代码。 每个代码必须是唯一的整数。" +msgstr "LULC栅格中的LULC代码。每个代码必须是唯一的整数。" #: src/natcap/invest/spec_utils.py:141 msgid "Map of elevation after any pits are filled" -msgstr "" +msgstr "填充所有坑洼后的海拔地图" #: src/natcap/invest/spec_utils.py:148 -#, fuzzy msgid "Map of flow accumulation" -msgstr "阈值流量累积" +msgstr "流量累积地图" #: src/natcap/invest/spec_utils.py:155 msgid "" -"MFD flow direction. Note: the pixel values should not be interpreted " -"directly. Each 32-bit number consists of 8 4-bit numbers. Each 4-bit " -"number represents the proportion of flow into one of the eight " -"neighboring pixels." -msgstr "" +"MFD flow direction. Note: the pixel values should not be interpreted directly. Each 32-bit number consists of 8 4-bit numbers. Each 4-bit number represents the " +"proportion of flow into one of the eight neighboring pixels." +msgstr "MFD流向。注意:像素值不应直接解释。每个32位数字由8个4位数字组成。每个4位数字表示流入八个相邻像素中的一个的比例。" #: src/natcap/invest/spec_utils.py:164 -#, fuzzy msgid "D8 flow direction." -msgstr "计算流向" +msgstr "D8流向。" #: src/natcap/invest/spec_utils.py:169 -msgid "" -"Percent slope, calculated from the pit-filled DEM. 100 is equivalent to a" -" 45 degree slope." -msgstr "" +msgid "Percent slope, calculated from the pit-filled DEM. 100 is equivalent to a 45 degree slope." +msgstr "从填充坑洼的DEM计算得出的百分比坡度。100等同于45度坡度。" #: src/natcap/invest/spec_utils.py:222 msgid "number of pixels" msgstr "像元数量" #: src/natcap/invest/spec_utils.py:231 -#, fuzzy msgid "unitless" msgstr "无单位的" #: src/natcap/invest/spec_utils.py:251 -#, fuzzy msgid "currency units" msgstr "货币单位" @@ -1870,7 +1599,6 @@ msgid "vector" msgstr "向量" #: src/natcap/invest/spec_utils.py:504 -#, fuzzy msgid "units" msgstr "单位" @@ -1883,9 +1611,7 @@ msgid " Please see the sample data table for details on the format." msgstr " 关于格式的细节,请参见样本数据表。" #: src/natcap/invest/stormwater.py:56 -msgid "" -"Event mean concentration of the pollutant in stormwater. You may include " -"any number of these columns for different pollutants, or none at all." +msgid "Event mean concentration of the pollutant in stormwater. You may include any number of these columns for different pollutants, or none at all." msgstr "雨水中污染物的事件平均浓度。你可以为不同的污染物包括任何数量的这些列,或者根本不包括。" #: src/natcap/invest/stormwater.py:65 @@ -1898,22 +1624,17 @@ msgstr "土壤组的雨水渗漏系数" #: src/natcap/invest/stormwater.py:84 msgid "" -"Enter 1 if the LULC class is a connected impervious surface, 0 if not. " -"This column is only used if the 'adjust retention ratios' option is " -"selected. If 'adjust retention ratios' is selected and this column " -"exists, the adjustment algorithm takes into account the LULC as well as " -"road centerlines. If this column does not exist, only the road " -"centerlines are used." +"Enter 1 if the LULC class is a connected impervious surface, 0 if not. This column is only used if the 'adjust retention ratios' option is selected. If 'adjust " +"retention ratios' is selected and this column exists, the adjustment algorithm takes into account the LULC as well as road centerlines. If this column does not exist, " +"only the road centerlines are used." msgstr "" -"如果LULC等级是连接的不透水表面,则输入1,如果不是则输入0。这一栏只有在选择了 \"调整保留率 \"选项时才会使用。如果选择了 " -"\"调整保留率\",并且这一栏存在,调整算法会考虑LULC和道路中心线。如果这一栏不存在,则只使用道路中心线。" +"如果LULC等级是连接的不透水表面,则输入1,如果不是则输入0。这一栏只有在选择了 \"调整保留率 \"选项时才会使用。如果选择了 \"调整保留率\",并且这一栏存在,调整算法会考虑" +"LULC和道路中心线。如果这一栏不存在,则只使用道路中心线。" #: src/natcap/invest/stormwater.py:95 msgid "" -"Table mapping each LULC code found in the LULC raster to biophysical data" -" about that LULC class. If you provide the percolation coefficient column" -" (PE_[X]) for any soil group, you must provide it for all four soil " -"groups." +"Table mapping each LULC code found in the LULC raster to biophysical data about that LULC class. If you provide the percolation coefficient column (PE_[X]) for any " +"soil group, you must provide it for all four soil groups." msgstr "将LULC栅格中的每个LULC代码与该LULC类别的生物物理数据进行映射的表格。如果你为任何土壤组提供渗滤系数列(PE_[X]),你必须为所有四个土壤组提供。" #: src/natcap/invest/stormwater.py:100 @@ -1922,12 +1643,9 @@ msgstr "生物物理表" #: src/natcap/invest/stormwater.py:104 msgid "" -"If true, adjust retention ratios. The adjustment algorithm accounts for " -"drainage effects of nearby impervious surfaces which are directly " -"connected to artifical urban drainage channels (typically roads, parking " -"lots, etc.) Connected impervious surfaces are indicated by the " -"is_connected columnin the biophysical table and/or the road centerlines " -"vector." +"If true, adjust retention ratios. The adjustment algorithm accounts for drainage effects of nearby impervious surfaces which are directly connected to artifical urban " +"drainage channels (typically roads, parking lots, etc.) Connected impervious surfaces are indicated by the is_connected columnin the biophysical table and/or the road " +"centerlines vector." msgstr "如果为真,则调整保留率。调整算法考虑了附近不透水表面的排水影响,这些不透水表面直接与城市人工排水道相连(通常是道路、停车场等)。" #: src/natcap/invest/stormwater.py:111 @@ -1936,13 +1654,11 @@ msgstr "调整保留率" #: src/natcap/invest/stormwater.py:117 msgid "" -"Radius around each pixel to adjust retention ratios. Measured in raster " -"coordinate system units. For the adjustment algorithm, a pixel is 'near' " -"a connected impervious surface if its centerpoint is within this radius " -"of connected-impervious LULC and/or a road centerline." +"Radius around each pixel to adjust retention ratios. Measured in raster coordinate system units. For the adjustment algorithm, a pixel is 'near' a connected impervious " +"surface if its centerpoint is within this radius of connected-impervious LULC and/or a road centerline." msgstr "" -"每个像素周围的半径,用于调整保留率。以栅格坐标系统单位测量。对于调整算法,如果一个像素的中心点在这个半径内的相连不透水的LULC和/或道路中心线内,则该像素" -" \"靠近 \"相连不透水的表面。" +"每个像素周围的半径,用于调整保留率。以栅格坐标系统单位测量。对于调整算法,如果一个像素的中心点在这个半径内的相连不透水的LULC和/或道路中心线内,则该像素 \"靠近 \"相连不" +"透水的表面。" #: src/natcap/invest/stormwater.py:123 msgid "Retention radius" @@ -1958,13 +1674,12 @@ msgstr "道路中心线" #: src/natcap/invest/stormwater.py:136 msgid "" -"Areas over which to aggregate results (typically watersheds or " -"sewersheds). The aggregated data are: average retention ratio and total " -"retention volume; average percolation ratio and total percolation volume " -"if percolation data was provided; total retention value if replacement " -"cost was provided; and total avoided pollutant load for each pollutant " -"provided." -msgstr "汇总结果的区域(通常是流域或污水流域)。汇总的数据是:平均保留率和总保留量;如果提供了渗滤数据,则提供平均渗滤率和总渗滤量;如果提供了重置成本,则提供总保留价值;以及所提供的每种污染物的总避免污染负荷。" +"Areas over which to aggregate results (typically watersheds or sewersheds). The aggregated data are: average retention ratio and total retention volume; average " +"percolation ratio and total percolation volume if percolation data was provided; total retention value if replacement cost was provided; and total avoided pollutant " +"load for each pollutant provided." +msgstr "" +"汇总结果的区域(通常是流域或污水流域)。汇总的数据是:平均保留率和总保留量;如果提供了渗滤数据,则提供平均渗滤率和总渗滤量;如果提供了重置成本,则提供总保留价值;以及所" +"提供的每种污染物的总避免污染负荷。" #: src/natcap/invest/stormwater.py:149 msgid "Replacement cost of stormwater retention devices" @@ -1975,208 +1690,165 @@ msgid "Replacement cost" msgstr "替换费用" #: src/natcap/invest/stormwater.py:155 -msgid "" -"Map of the stormwater retention ratio, derived from the LULC raster and " -"biophysical table RC_x columns." -msgstr "" +msgid "Map of the stormwater retention ratio, derived from the LULC raster and biophysical table RC_x columns." +msgstr "从LULC栅格和生物物理表的RC_x列导出的暴雨滞留比地图。" #: src/natcap/invest/stormwater.py:162 msgid "" -"Map of the adjusted retention ratio, calculated according to equation " -"(124) from the ‘retention_ratio, ratio_average, near_road’, and " -"‘near_impervious_lulc’ intermediate outputs." -msgstr "" +"Map of the adjusted retention ratio, calculated according to equation (124) from the ‘retention_ratio, ratio_average, near_road’, and ‘near_impervious_lulc’ " +"intermediate outputs." +msgstr "根据'滞留比、比率平均值、临近道路'和'临近不透水LULC'中间输出的方程(124)计算得出的调整后的滞留比地图。" #: src/natcap/invest/stormwater.py:169 -#, fuzzy msgid "Map of retention volume." -msgstr "蒸发量值地图。" +msgstr "滞留容积地图。" #: src/natcap/invest/stormwater.py:177 -msgid "" -"Map of percolation ratio derived by cross-referencing the LULC and soil " -"group rasters with the biophysical table." -msgstr "" +msgid "Map of percolation ratio derived by cross-referencing the LULC and soil group rasters with the biophysical table." +msgstr "通过将LULC和土壤组栅格与生物物理表进行交叉参考得出的渗透比地图。" #: src/natcap/invest/stormwater.py:184 msgid "Map of percolation (potential aquifer recharge) volume." -msgstr "" +msgstr "渗透(潜在含水层补给)容积地图。" #: src/natcap/invest/stormwater.py:191 -msgid "" -"Map of the stormwater runoff ratio. This is the inverse of " -"‘retention_ratio.tif’" -msgstr "" +msgid "Map of the stormwater runoff ratio. This is the inverse of ‘retention_ratio.tif’" +msgstr "雨水径流比率图。这与“retention_ratio.tif”相反。" #: src/natcap/invest/stormwater.py:197 msgid "Map of runoff volume." -msgstr "" +msgstr "径流体积图。" #: src/natcap/invest/stormwater.py:205 msgid "Map of the value of water retained." -msgstr "" +msgstr "蓄水值图。" #: src/natcap/invest/stormwater.py:213 -msgid "" -"Map of aggregate data. This is identical to the aggregate areas input " -"vector, but each polygon is given additional fields with the aggregate " -"data." -msgstr "" +msgid "Map of aggregate data. This is identical to the aggregate areas input vector, but each polygon is given additional fields with the aggregate data." +msgstr "聚合数据图。这与聚合区域输入向量相同,但每个面都具有聚合数据的附加字段。" #: src/natcap/invest/stormwater.py:221 msgid "Average retention ratio over this polygon" -msgstr "" +msgstr "此多边形的平均保留率" #: src/natcap/invest/stormwater.py:226 msgid "Total retention volume over this polygon" -msgstr "" +msgstr "此多边形上的总保留体积" #: src/natcap/invest/stormwater.py:230 -#, fuzzy msgid "Average runoff coefficient over this polygon" -msgstr "土壤组的雨水径流系数" +msgstr "该多边形的平均径流系数" #: src/natcap/invest/stormwater.py:235 msgid "Total runoff volume over this polygon" -msgstr "" +msgstr "此多边形上的总径流体积" #: src/natcap/invest/stormwater.py:239 msgid "Average percolation (recharge) ratio over this polygon" -msgstr "" +msgstr "该多边形上的平均渗透(补给)率" #: src/natcap/invest/stormwater.py:244 msgid "Total volume of potential aquifer recharge over this polygon" -msgstr "" +msgstr "该多边形上潜在含水层补给总量" #: src/natcap/invest/stormwater.py:249 msgid "Total avoided (retained) amount of pollutant over this polygon" -msgstr "" +msgstr "此多边形上避免(保留)的污染物总量" #: src/natcap/invest/stormwater.py:254 msgid "Total amount of pollutant in runoff over this polygon" -msgstr "" +msgstr "该多边形上径流中的污染物总量" #: src/natcap/invest/stormwater.py:260 msgid "Total value of the retained volume of water over this polygon" -msgstr "" +msgstr "此多边形上的保留水量的总值" #: src/natcap/invest/stormwater.py:270 -msgid "" -"Copy of the soil group raster input, cropped to the intersection of the " -"three raster inputs." -msgstr "" +msgid "Copy of the soil group raster input, cropped to the intersection of the three raster inputs." +msgstr "土壤组栅格输入的副本,裁剪至三个栅格输入的交点。" #: src/natcap/invest/stormwater.py:276 -msgid "" -"Copy of the soil group raster input, aligned to the LULC raster and " -"cropped to the intersection of the three raster inputs." -msgstr "" +msgid "Copy of the soil group raster input, aligned to the LULC raster and cropped to the intersection of the three raster inputs." +msgstr "土壤组栅格输入的副本,与LULC栅格对齐并裁剪到三个栅格输入的交点。" #: src/natcap/invest/stormwater.py:283 -msgid "" -"Copy of the precipitation raster input, aligned to the LULC raster and " -"cropped to the intersection of the three raster inputs." -msgstr "" +msgid "Copy of the precipitation raster input, aligned to the LULC raster and cropped to the intersection of the three raster inputs." +msgstr "降水栅格输入的副本,与LULC栅格对齐并裁剪至三个栅格输入的交点。" #: src/natcap/invest/stormwater.py:295 -msgid "" -"Copy of the road centerlines vector input, reprojected to the LULC raster" -" projection." -msgstr "" +msgid "Copy of the road centerlines vector input, reprojected to the LULC raster projection." +msgstr "道路中心线矢量输入的副本,重新投影到LULC栅格投影。" #: src/natcap/invest/stormwater.py:303 -msgid "" -"A rasterized version of the reprojected centerlines vector, where 1 means" -" the pixel is a road and 0 means it isn’t." -msgstr "" +msgid "A rasterized version of the reprojected centerlines vector, where 1 means the pixel is a road and 0 means it isn’t." +msgstr "重新投影的中心线矢量的栅格化版本,其中1表示像素是道路,0表示不是道路。" #: src/natcap/invest/stormwater.py:310 msgid "" -"A binary raster derived from the LULC raster and biophysical table " -"is_connected column, where 1 means the pixel has a directly-connected " -"impervious LULC type, and 0 means it does not." -msgstr "" +"A binary raster derived from the LULC raster and biophysical table is_connected column, where 1 means the pixel has a directly-connected impervious LULC type, and 0 " +"means it does not." +msgstr "从LULC栅格和生物物理表中派生的二进制栅格是_connected列,其中1表示像素具有直连的不可渗透LULC类型,0表示不具有直连的不可渗透类型。" #: src/natcap/invest/stormwater.py:318 -msgid "" -"A raster derived from the rasterized centerlines map, where each pixel’s " -"value is its minimum distance to a road pixel (measured centerpoint-to-" -"centerpoint)." -msgstr "" +msgid "A raster derived from the rasterized centerlines map, where each pixel’s value is its minimum distance to a road pixel (measured centerpoint-to-centerpoint)." +msgstr "从栅格化的中心线地图派生的栅格,其中每个像素的值是其到道路像素的最小距离(测量的中心点到中心点)。" #: src/natcap/invest/stormwater.py:328 msgid "" -"A raster derived from the is_connected_lulc map, where each pixel’s value" -" is its minimum distance to a connected impervious LULC pixel (measured " -"centerpoint-to-centerpoint)." -msgstr "" +"A raster derived from the is_connected_lulc map, where each pixel’s value is its minimum distance to a connected impervious LULC pixel (measured centerpoint-to-" +"centerpoint)." +msgstr "从is_connected_lulc地图派生的栅格,其中每个像素的值是其与相连的不透水lulc像素的最小距离(中心点到中心点的测量值)。" #: src/natcap/invest/stormwater.py:339 -msgid "" -"A binary raster derived from the road_distance map, where 1 means the " -"pixel is within the retention radius of a road pixel, and 0 means it " -"isn’t." -msgstr "" +msgid "A binary raster derived from the road_distance map, where 1 means the pixel is within the retention radius of a road pixel, and 0 means it isn’t." +msgstr "从road_distance地图派生的二进制栅格,其中1表示像素在道路像素的保留半径内,0表示不在保留半径内。" #: src/natcap/invest/stormwater.py:346 msgid "" -"A binary raster derived from the connected_lulc_distance map, where 1 " -"means the pixel is within the retention radius of a connected impervious " -"LULC pixel, and 0 means it isn’t." -msgstr "" +"A binary raster derived from the connected_lulc_distance map, where 1 means the pixel is within the retention radius of a connected impervious LULC pixel, and 0 means " +"it isn’t." +msgstr "从connected_lulc_distance地图派生的二进制栅格,其中1表示像素在连接的不可渗透lulc像素的保留半径内,0表示不在此范围内。" #: src/natcap/invest/stormwater.py:354 msgid "" -"A binary raster representing the search kernel that is convolved with the" -" retention_ratio raster to calculate the averaged retention ratio within " -"the retention radius of each pixel." -msgstr "" +"A binary raster representing the search kernel that is convolved with the retention_ratio raster to calculate the averaged retention ratio within the retention radius " +"of each pixel." +msgstr "表示搜索内核的二进制栅格,与retention_ratio栅格进行卷积以计算每个像素保留半径内的平均保留率。" #: src/natcap/invest/stormwater.py:362 msgid "" -"A raster where each pixel’s value is the average of its neighborhood of " -"pixels in the retention_ratio map, calculated by convolving the search " -"kernel with the retention ratio raster." -msgstr "" +"A raster where each pixel’s value is the average of its neighborhood of pixels in the retention_ratio map, calculated by convolving the search kernel with the " +"retention ratio raster." +msgstr "一种栅格,其中每个像素的值是retention_ratio地图中其邻域像素的平均值,通过将搜索核与保留率栅格进行卷积来计算。" #: src/natcap/invest/urban_cooling_model.py:49 -msgid "" -"Map of LULC for the area of interest. All values in this raster must have" -" corresponding entries in the Biophysical Table." +msgid "Map of LULC for the area of interest. All values in this raster must have corresponding entries in the Biophysical Table." msgstr "所关注区域的LULC地图。该栅格中的所有数值必须在生物物理表中有相应的条目。" #: src/natcap/invest/urban_cooling_model.py:68 -msgid "" -"Enter 1 to indicate that the LULC is considered a green area. Enter 0 to " -"indicate that the LULC is not considered a green area." +msgid "Enter 1 to indicate that the LULC is considered a green area. Enter 0 to indicate that the LULC is not considered a green area." msgstr "输入1表示该LULC被认为是绿色区域。输入 0 表示该 LULC 不被视为绿色区域。" #: src/natcap/invest/urban_cooling_model.py:75 msgid "" -"The proportion of area in this LULC class that is covered by tree canopy " -"at least 2 meters high. Required if the 'factors' option is selected for " -"the Cooling Capacity Calculation Method." +"The proportion of area in this LULC class that is covered by tree canopy at least 2 meters high. Required if the 'factors' option is selected for the Cooling Capacity " +"Calculation Method." msgstr "该LULC等级中被至少2米高的树冠覆盖的面积比例。如果冷却能力计算方法选择 \"因素 \"选项,则需要。" #: src/natcap/invest/urban_cooling_model.py:83 msgid "" -"The proportion of solar radiation that is directly reflected by this LULC" -" class. Required if the 'factors' option is selected for the Cooling " -"Capacity Calculation Method." +"The proportion of solar radiation that is directly reflected by this LULC class. Required if the 'factors' option is selected for the Cooling Capacity Calculation " +"Method." msgstr "该LULC等级直接反射的太阳辐射的比例。如果冷却能力计算方法选择 \"因素 \"选项,则需要。" #: src/natcap/invest/urban_cooling_model.py:91 msgid "" -"The ratio of building floor area to footprint area, with all values in " -"this column normalized between 0 and 1. Required if the 'intensity' " -"option is selected for the Cooling Capacity Calculation Method." +"The ratio of building floor area to footprint area, with all values in this column normalized between 0 and 1. Required if the 'intensity' option is selected for the " +"Cooling Capacity Calculation Method." msgstr "建筑物面积与占地面积的比率,这一栏中的所有数值都在0和1之间归一化。 如果冷却能力计算方法选择了 \"强度 \"选项,则需要。" #: src/natcap/invest/urban_cooling_model.py:98 -msgid "" -"A table mapping each LULC code to biophysical data for that LULC class. " -"All values in the LULC raster must have corresponding entries in this " -"table." +msgid "A table mapping each LULC code to biophysical data for that LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "将每个LULC代码映射到该LULC等级的生物物理数据的表格。LULC栅格中的所有数值必须在此表中有相应的条目。" #: src/natcap/invest/urban_cooling_model.py:107 @@ -2184,9 +1856,7 @@ msgid "maximum cooling distance" msgstr "最大冷却距离" #: src/natcap/invest/urban_cooling_model.py:108 -msgid "" -"Distance over which green areas larger than 2 hectares have a cooling " -"effect." +msgid "Distance over which green areas larger than 2 hectares have a cooling effect." msgstr "大于2公顷的绿地具有冷却效果的距离。" #: src/natcap/invest/urban_cooling_model.py:116 @@ -2202,9 +1872,7 @@ msgid "reference air temperature" msgstr "参考空气温度" #: src/natcap/invest/urban_cooling_model.py:125 -msgid "" -"Air temperature in a rural reference area where the urban heat island " -"effect is not observed." +msgid "Air temperature in a rural reference area where the urban heat island effect is not observed." msgstr "在没有观察到城市热岛效应的农村参考地区的空气温度。" #: src/natcap/invest/urban_cooling_model.py:130 @@ -2212,10 +1880,7 @@ msgid "UHI effect" msgstr "城市热岛效应" #: src/natcap/invest/urban_cooling_model.py:133 -msgid "" -"The magnitude of the urban heat island effect, i.e., the difference " -"between the rural reference temperature and the maximum temperature " -"observed in the city." +msgid "The magnitude of the urban heat island effect, i.e., the difference between the rural reference temperature and the maximum temperature observed in the city." msgstr "城市热岛效应的大小,即农村参考温度与城市中观察到的最高温度之间的差异。" #: src/natcap/invest/urban_cooling_model.py:139 @@ -2239,9 +1904,7 @@ msgid "average relative humidity" msgstr "平均相对湿度" #: src/natcap/invest/urban_cooling_model.py:152 -msgid "" -"The average relative humidity over the time period of interest. Required " -"if Run Work Productivity Valuation is selected." +msgid "The average relative humidity over the time period of interest. Required if Run Work Productivity Valuation is selected." msgstr "所关注的时间段内的平均相对湿度。如果选择了运行工作生产力评估,则需要。" #: src/natcap/invest/urban_cooling_model.py:158 @@ -2249,15 +1912,11 @@ msgid "buildings" msgstr "建筑" #: src/natcap/invest/urban_cooling_model.py:163 -msgid "" -"Code indicating the building type. These codes must match those in the " -"Energy Consumption Table." +msgid "Code indicating the building type. These codes must match those in the Energy Consumption Table." msgstr "表示建筑类型的代码。这些代码必须与能源消耗表中的代码一致。" #: src/natcap/invest/urban_cooling_model.py:168 -msgid "" -"A map of built infrastructure footprints. Required if Run Energy Savings " -"Valuation is selected." +msgid "A map of built infrastructure footprints. Required if Run Energy Savings Valuation is selected." msgstr "已建基础设施足迹的地图。如果选择运行能源节约评估,则需要。" #: src/natcap/invest/urban_cooling_model.py:173 @@ -2273,16 +1932,11 @@ msgid "Energy consumption by footprint area for this building type." msgstr "该建筑类型按占地面积计算的能源消耗。" #: src/natcap/invest/urban_cooling_model.py:194 -msgid "" -"The cost of electricity for this building type. If this column is " -"provided, the energy savings outputs will be in the this currency unit " -"rather than kWh." +msgid "The cost of electricity for this building type. If this column is provided, the energy savings outputs will be in the this currency unit rather than kWh." msgstr "该建筑类型的电力成本。如果提供了这一栏,节能输出将以货币为单位而非千瓦时为单位。" #: src/natcap/invest/urban_cooling_model.py:202 -msgid "" -"A table of energy consumption data for each building type. Required if " -"Run Energy Savings Valuation is selected." +msgid "A table of energy consumption data for each building type. Required if Run Energy Savings Valuation is selected." msgstr "每种建筑类型的能源消耗数据表格。如果选择运行能源节约评估,则需要。" #: src/natcap/invest/urban_cooling_model.py:207 @@ -2294,9 +1948,7 @@ msgid "factors" msgstr "因素" #: src/natcap/invest/urban_cooling_model.py:212 -msgid "" -"Use the weighted shade, albedo, and ETI factors as a temperature " -"predictor (for daytime temperatures)." +msgid "Use the weighted shade, albedo, and ETI factors as a temperature predictor (for daytime temperatures)." msgstr "使用加权阴影、反照率和ETI因子作为温度预测器(针对白天的温度)。" #: src/natcap/invest/urban_cooling_model.py:216 @@ -2304,9 +1956,7 @@ msgid "intensity" msgstr "强度" #: src/natcap/invest/urban_cooling_model.py:217 -msgid "" -"Use building intensity as a temperature predictor (for nighttime " -"temperatures)." +msgid "Use building intensity as a temperature predictor (for nighttime temperatures)." msgstr "使用建筑强度作为温度预测器(针对夜间温度)。" #: src/natcap/invest/urban_cooling_model.py:221 @@ -2318,9 +1968,7 @@ msgid "shade weight" msgstr "阴影权重" #: src/natcap/invest/urban_cooling_model.py:227 -msgid "" -"The relative weight to apply to shade when calculating the cooling " -"capacity index. If not provided, defaults to 0.6." +msgid "The relative weight to apply to shade when calculating the cooling capacity index. If not provided, defaults to 0.6." msgstr "计算冷却能力指数时适用于阴凉处的相对权重。如果没有提供,默认为0.6。" #: src/natcap/invest/urban_cooling_model.py:232 @@ -2328,9 +1976,7 @@ msgid "albedo weight" msgstr "反照率权重" #: src/natcap/invest/urban_cooling_model.py:235 -msgid "" -"The relative weight to apply to albedo when calculating the cooling " -"capacity index. If not provided, defaults to 0.2." +msgid "The relative weight to apply to albedo when calculating the cooling capacity index. If not provided, defaults to 0.2." msgstr "计算冷却能力指数时应用于反照率的相对权重。如果没有提供,默认为0.2。" #: src/natcap/invest/urban_cooling_model.py:240 @@ -2338,9 +1984,7 @@ msgid "evapotranspiration weight" msgstr "蒸发权重" #: src/natcap/invest/urban_cooling_model.py:243 -msgid "" -"The relative weight to apply to ETI when calculating the cooling capacity" -" index. If not provided, defaults to 0.2." +msgid "The relative weight to apply to ETI when calculating the cooling capacity index. If not provided, defaults to 0.2." msgstr "计算冷却能力指数时,应用于ETI的相对权重。如果没有提供,默认为0.2。" #: src/natcap/invest/urban_flood_risk_mitigation.py:44 @@ -2352,9 +1996,7 @@ msgid "rainfall depth" msgstr "降雨深度" #: src/natcap/invest/urban_flood_risk_mitigation.py:50 -msgid "" -"Map of LULC. All values in this raster must have corresponding entries in" -" the Biophysical Table." +msgid "Map of LULC. All values in this raster must have corresponding entries in the Biophysical Table." msgstr "LULC的地图。该栅格中的所有数值必须在生物物理表中有相应的条目。" #: src/natcap/invest/urban_flood_risk_mitigation.py:68 @@ -2362,16 +2004,11 @@ msgid "The curve number value for this LULC type in the soil group code" msgstr "该LULC类型在土壤组代码中的曲线数字值" #: src/natcap/invest/urban_flood_risk_mitigation.py:73 -msgid "" -"Table of curve number data for each LULC class. All LULC codes in the " -"LULC raster must have corresponding entries in this table for each soil " -"group." +msgid "Table of curve number data for each LULC class. All LULC codes in the LULC raster must have corresponding entries in this table for each soil group." msgstr "每个LULC等级的曲线编号数据表。LULC栅格中的所有LULC代码必须在此表中有每个土壤组的对应条目。" #: src/natcap/invest/urban_flood_risk_mitigation.py:84 -msgid "" -"Code indicating the building type. These codes must match those in the " -"Damage Loss Table." +msgid "Code indicating the building type. These codes must match those in the Damage Loss Table." msgstr "表示建筑物类型的代码。这些代码必须与损坏损失表中的代码一致。" #: src/natcap/invest/urban_flood_risk_mitigation.py:90 @@ -2392,10 +2029,8 @@ msgstr "这种建筑类型的潜在破坏损失。" #: src/natcap/invest/urban_flood_risk_mitigation.py:106 msgid "" -"Table of potential damage loss data for each building type. All values in" -" the Built Infrastructure vector 'type' field must have corresponding " -"entries in this table. Required if the Built Infrastructure vector is " -"provided." +"Table of potential damage loss data for each building type. All values in the Built Infrastructure vector 'type' field must have corresponding entries in this table. " +"Required if the Built Infrastructure vector is provided." msgstr "每个建筑类型的潜在破坏损失数据表。基础设施建设矢量 \"类型 \"字段中的所有数值必须在此表中有相应的条目。如果提供建筑基础设施向量,则需要。" #: src/natcap/invest/urban_flood_risk_mitigation.py:111 @@ -2404,222 +2039,165 @@ msgstr "危害损失表" #: src/natcap/invest/urban_nature_access.py:130 msgid "" -"The proportion of the population within each administrative unit " -"belonging to the identified population group (POP_GROUP). At least one " -"column with the prefix 'pop_' is required when aggregating output by " -"population groups." -msgstr "" +"The proportion of the population within each administrative unit belonging to the identified population group (POP_GROUP). At least one column with the prefix 'pop_' " +"is required when aggregating output by population groups." +msgstr "每个行政单位中属于已确定人口群体的人口比例。按群体组汇总输出时,至少需要一个前缀为“pop_”的列。" #: src/natcap/invest/urban_nature_access.py:139 msgid "" -"A vector representing administrative units. Polygons representing " -"administrative units should not overlap. Overlapping administrative " -"geometries may cause unexpected results and for this reason should not " -"overlap." -msgstr "" +"A vector representing administrative units. Polygons representing administrative units should not overlap. Overlapping administrative geometries may cause unexpected " +"results and for this reason should not overlap." +msgstr "代表行政单位的向量。表示行政单位的多边形不应重叠。重叠的管理几何可能会导致意外结果,因此不应重叠。" #: src/natcap/invest/urban_nature_access.py:151 -msgid "" -"The amount of urban nature that each resident should have access to. This" -" is often defined by local urban planning documents." -msgstr "" +msgid "The amount of urban nature that each resident should have access to. This is often defined by local urban planning documents." +msgstr "每个居民应该接触的城市自然的数量。这通常由当地的城市规划文件来定义。" #: src/natcap/invest/urban_nature_access.py:163 -msgid "" -"All pixels within the search radius contribute equally to an urban nature" -" pixel." -msgstr "" +msgid "All pixels within the search radius contribute equally to an urban nature pixel." +msgstr "搜索半径内的所有像素对城市自然像素的贡献相等。" #: src/natcap/invest/urban_nature_access.py:169 -msgid "" -"Contributions to an urban nature pixel decrease exponentially, where " -"\"weight = e^(-pixel_dist / search_radius)\"" -msgstr "" +msgid "Contributions to an urban nature pixel decrease exponentially, where \"weight = e^(-pixel_dist / search_radius)\"" +msgstr "对城市自然像素的贡献呈指数下降,其中“权重= e^(-pixel_dist /搜索半径)”" #: src/natcap/invest/urban_nature_access.py:176 -msgid "" -"Contributions to an urban nature pixel decrease according to a normal " -"(\"gaussian\") distribution with a sigma of 3." -msgstr "" +msgid "Contributions to an urban nature pixel decrease according to a normal (\"gaussian\") distribution with a sigma of 3." +msgstr "对城市自然像素的贡献根据σ为3的正态(“高斯”)分布而减少。" #: src/natcap/invest/urban_nature_access.py:183 msgid "" -"Contributions to an urban nature pixel decrease faster as distances " -"approach the search radius. Weights are calculated by \"weight = 0.75 * " -"(1-(pixel_dist / search_radius)^2)\"" -msgstr "" +"Contributions to an urban nature pixel decrease faster as distances approach the search radius. Weights are calculated by \"weight = 0.75 * (1-(pixel_dist / " +"search_radius)^2)\"" +msgstr "随着距离接近搜索半径,对城市自然像素的贡献下降得更快。权重的计算方法是“权重= 0.75 *(1-(像素距离/ search_radius)^2)”" #: src/natcap/invest/urban_nature_access.py:210 msgid "The type of search radius to use." -msgstr "" +msgstr "要使用的搜索半径类型。" #: src/natcap/invest/urban_nature_access.py:216 msgid "The search radius is the same for all types of urban nature." -msgstr "" +msgstr "所有类型的城市自然的搜索半径都是相同的。" #: src/natcap/invest/urban_nature_access.py:222 -msgid "" -"The search radius is defined for each distinct urban nature LULC " -"classification." -msgstr "" +msgid "The search radius is defined for each distinct urban nature LULC classification." +msgstr "为每个不同的城市自然LULC分类定义搜索半径。" #: src/natcap/invest/urban_nature_access.py:228 msgid "The search radius is defined for each distinct population group." -msgstr "" +msgstr "为每个不同的群体定义搜索半径。" #: src/natcap/invest/urban_nature_access.py:238 msgid "" -"Whether to aggregate statistics by population group within each " -"administrative unit. If selected, population groups will be read from the" -" fields of the user-defined administrative boundaries vector. This option" -" is implied if the search radii are defined by population groups." -msgstr "" +"Whether to aggregate statistics by population group within each administrative unit. If selected, population groups will be read from the fields of the user-defined " +"administrative boundaries vector. This option is implied if the search radii are defined by population groups." +msgstr "是否在每个行政单位内按人口组汇总统计数据。如果选中,将从用户定义的行政边界向量的字段中读取人口组。如果搜索半径由人群定义,则此选项是隐含的。" #: src/natcap/invest/urban_nature_access.py:252 -msgid "" -"The search radius to use when running the model under a uniform search " -"radius. Required when running the model with a uniform search radius. " -"Units are in meters." -msgstr "" +msgid "The search radius to use when running the model under a uniform search radius. Required when running the model with a uniform search radius. Units are in meters." +msgstr "在统一搜索半径下运行模型时使用的搜索半径。使用统一搜索半径运行模型时需要。单位为米。" #: src/natcap/invest/urban_nature_access.py:266 -msgid "" -"The name of the population group. Names must match the names defined in " -"the administrative boundaries vector." -msgstr "" +msgid "The name of the population group. Names must match the names defined in the administrative boundaries vector." +msgstr "人口组的名称。名称必须与管理边界向量中定义的名称相匹配。" #: src/natcap/invest/urban_nature_access.py:276 -msgid "" -"The search radius in meters to use for this population group. Values " -"must be >= 0." -msgstr "" +msgid "The search radius in meters to use for this population group. Values must be >= 0." +msgstr "用于此人口组的搜索半径(米)。值必须大于等于0。" #: src/natcap/invest/urban_nature_access.py:282 msgid "" -"A table associating population groups with the distance in meters that " -"members of the population group will, on average, travel to find urban " -"nature. Required when running the model with search radii defined per " -"population group." -msgstr "" +"A table associating population groups with the distance in meters that members of the population group will, on average, travel to find urban nature. Required when " +"running the model with search radii defined per population group." +msgstr "将人口组与人口组成员平均寻找城市自然的距离(米)相关联的表。运行按人口组定义搜索半径的模型时需要。" #: src/natcap/invest/urban_nature_access.py:418 msgid "" -"Positive pixel values indicate an oversupply of urban nature for the " -"population group POP_GROUP relative to the stated urban nature demand. " -"Negative values indicate an undersupply of urban nature for the " -"population group POP_GROUP relative to the stated urban nature demand." -msgstr "" +"Positive pixel values indicate an oversupply of urban nature for the population group POP_GROUP relative to the stated urban nature demand. Negative values indicate an " +"undersupply of urban nature for the population group POP_GROUP relative to the stated urban nature demand." +msgstr "正像素值表示相对于规定的城市自然需求,人口群体POP_GROUP的城市自然供过于求。负值表示相对于规定的城市自然需求,人口群体POP_GROUP的城市自然供给不足。" #: src/natcap/invest/urban_nature_access.py:432 -msgid "" -"The area of greenspace available within the defined radius, weighted by " -"the selected decay function." -msgstr "" +msgid "The area of greenspace available within the defined radius, weighted by the selected decay function." +msgstr "在定义的半径内可用的绿地面积,由选定的衰减函数加权。" #: src/natcap/invest/urban_nature_access.py:442 -msgid "" -"The area of greenspace available within the radius associated with urban " -"nature class LUCODE, weighted by the selected decay function." -msgstr "" +msgid "The area of greenspace available within the radius associated with urban nature class LUCODE, weighted by the selected decay function." +msgstr "在与城市自然等级LUCODE相关的半径范围内可用的绿地面积,由选定的衰减函数进行加权。" #: src/natcap/invest/urban_nature_access.py:453 -msgid "" -"The area of greenspace available within the radius associated with group " -"POP_GROUP, weighted by the selected decay function." -msgstr "" +msgid "The area of greenspace available within the radius associated with group POP_GROUP, weighted by the selected decay function." +msgstr "在与组POP_GROUP相关的半径内可用的绿地面积,由所选衰减函数加权。" #: src/natcap/invest/urban_nature_access.py:467 -msgid "" -"A copy of the user's land use land cover raster. If the user-supplied " -"LULC has non-square pixels, they will be resampled to square pixels in " -"this raster." -msgstr "" +msgid "A copy of the user's land use land cover raster. If the user-supplied LULC has non-square pixels, they will be resampled to square pixels in this raster." +msgstr "用户土地利用土地覆盖栅格的副本。如果用户提供的LULC具有非方形像素,它们将在此栅格中被重新采样为方形像素。" #: src/natcap/invest/urban_nature_access.py:475 -msgid "" -"The user's population raster, aligned to the same resolution and " -"dimensions as the aligned LULC." -msgstr "" +msgid "The user's population raster, aligned to the same resolution and dimensions as the aligned LULC." +msgstr "用户的人口栅格,与已对齐的LULC具有相同的分辨率和尺寸。" #: src/natcap/invest/urban_nature_access.py:481 msgid "The population experiencing an urban nature deficit." -msgstr "" +msgstr "经历城市自然赤字的人口。" #: src/natcap/invest/urban_nature_access.py:487 msgid "The population experiencing an urban nature surplus." -msgstr "" +msgstr "经历城市自然盈余的人口。" #: src/natcap/invest/urban_nature_access.py:495 -msgid "" -"A sum of the population within the given search radius SEARCH_RADIUS, " -"weighted by the user's decay function." -msgstr "" +msgid "A sum of the population within the given search radius SEARCH_RADIUS, weighted by the user's decay function." +msgstr "给定搜索半径SEARCH_RADIUS内人口的总和,由用户衰减函数加权。" #: src/natcap/invest/urban_nature_access.py:505 msgid "The area of urban nature (in square meters) represented in each pixel." -msgstr "" +msgstr "每个像素中表示的城市自然面积(以平方米为单位)。" #: src/natcap/invest/urban_nature_access.py:514 msgid "The calculated urban nature/population ratio." -msgstr "" +msgstr "计算出的城市自然/人口比率。" #: src/natcap/invest/urban_nature_access.py:523 msgid "" -"Pixel values represent the ares of urban nature (in square meters) " -"represented in each pixel for the urban nature class represented by the " -"land use land cover code LUCODE." -msgstr "" +"Pixel values represent the ares of urban nature (in square meters) represented in each pixel for the urban nature class represented by the land use land cover code " +"LUCODE." +msgstr "像素值表示城市自然的面积(以平方米为单位),城市自然类别由土地利用土地覆被代码LUCODE表示。" #: src/natcap/invest/urban_nature_access.py:533 -msgid "" -"The urban nature supplied to populations due to the land use land cover " -"code LUCODE" -msgstr "" +msgid "The urban nature supplied to populations due to the land use land cover code LUCODE" +msgstr "由于土地利用土地覆盖代码LUCODE,为人口提供了城市自然资源" #: src/natcap/invest/urban_nature_access.py:541 -msgid "" -"The calculated urban nature/population ratio for the urban nature class " -"represented by the land use land cover code LUCODE." -msgstr "" +msgid "The calculated urban nature/population ratio for the urban nature class represented by the land use land cover code LUCODE." +msgstr "由土地利用土地覆被代码LUCODE表示的城市自然类别的计算城市自然/人口比率。" #: src/natcap/invest/urban_nature_access.py:552 -msgid "" -"Each pixel represents the population of a pixel belonging to the " -"population in the population group POP_GROUP." -msgstr "" +msgid "Each pixel represents the population of a pixel belonging to the population in the population group POP_GROUP." +msgstr "每个像素代表属于群体组POP_GROUP中的群体的像素的群体。" #: src/natcap/invest/urban_nature_access.py:561 -msgid "" -"Each pixel represents the proportion of the total population that belongs" -" to the population group POP_GROUP." -msgstr "" +msgid "Each pixel represents the proportion of the total population that belongs to the population group POP_GROUP." +msgstr "每个像素代表属于人口组POP_GROUP的人口占总人口的比例。" #: src/natcap/invest/urban_nature_access.py:570 -msgid "" -"Each pixel represents the total number of people within the search radius" -" for the population group POP_GROUP, weighted by the user's selection of " -"decay function." -msgstr "" +msgid "Each pixel represents the total number of people within the search radius for the population group POP_GROUP, weighted by the user's selection of decay function." +msgstr "每个像素代表人口组POP_GROUP的搜索半径内的总人数,由用户选择的衰减函数进行加权。" #: src/natcap/invest/urban_nature_access.py:580 msgid "The total population, weighted by the appropriate decay function." -msgstr "" +msgstr "通过适当的衰减函数加权的总人口。" #: src/natcap/invest/urban_nature_access.py:588 msgid "The urban nature supply per capita to population group POP_GROUP." -msgstr "" +msgstr "人口群体人均城市自然供应量POP_GROUP。" #: src/natcap/invest/urban_nature_access.py:596 -msgid "" -"The population in population group POP_GROUP that are experiencing an " -"urban nature deficit." -msgstr "" +msgid "The population in population group POP_GROUP that are experiencing an urban nature deficit." +msgstr "人口群体POP_GROUP中的人口正在经历城市自然赤字。" #: src/natcap/invest/urban_nature_access.py:604 -msgid "" -"The population in population group POP_GROUP that are experiencing an " -"urban nature surplus." -msgstr "" +msgid "The population in population group POP_GROUP that are experiencing an urban nature surplus." +msgstr "人口群体POP_GROUP中正在经历城市自然盈余的人口。" #: src/natcap/invest/validation.py:33 msgid "Key is missing from the args dict" @@ -2634,16 +2212,11 @@ msgid "Expected the {header} \"{header_name}\" but did not find it" msgstr "期待{header}\"{header_name}\",但没有找到" #: src/natcap/invest/validation.py:37 -#, fuzzy -msgid "" -"Expected to find at least one {header} matching the pattern " -"\"{header_name}\" but found none" -msgstr "期待{header}\"{header_name}\",但没有找到" +msgid "Expected to find at least one {header} matching the pattern \"{header_name}\" but found none" +msgstr "应至少找到一个与模式“{header_name}”匹配的{header},但未找到" #: src/natcap/invest/validation.py:40 -msgid "" -"Expected the {header} \"{header_name}\" only once but found it {number} " -"times" +msgid "Expected the {header} \"{header_name}\" only once but found it {number} times" msgstr "预计{header}\"{header_name}\"只有一次,但发现它有{number}次" #: src/natcap/invest/validation.py:43 @@ -2651,9 +2224,7 @@ msgid "Value \"{value}\" could not be interpreted as a number" msgstr "值\"{value}\"不能被解释为一个数字" #: src/natcap/invest/validation.py:45 -msgid "" -"Layer must be projected in this unit: \"{unit_a}\" but found this unit: " -"\"{unit_b}\"" +msgid "Layer must be projected in this unit: \"{unit_a}\" but found this unit: \"{unit_b}\"" msgstr "层必须投射在这个单位。\"{unit_a}\"但发现这个单位是\"{unit_b}\"" #: src/natcap/invest/validation.py:48 @@ -2721,10 +2292,8 @@ msgid "Spatial file {filepath} has no projection" msgstr "空间文件{filepath}没有投影" #: src/natcap/invest/validation.py:65 -msgid "" -"Not all of the spatial layers overlap each other. All bounding boxes must" -" intersect: {bboxes}" -msgstr "" +msgid "Not all of the spatial layers overlap each other. All bounding boxes must intersect: {bboxes}" +msgstr "并非所有的空间层都相互重叠。所有边界框必须相交:{bboxes}" #: src/natcap/invest/validation.py:68 msgid "You must have {permission} access to this file" @@ -2732,19 +2301,19 @@ msgstr "你必须有{permission}的权限来访问这个文件" #: src/natcap/invest/validation.py:70 msgid "Geometry type must be one of {allowed}" -msgstr "" +msgstr "几何类型必须是{allowed}之一" #: src/natcap/invest/wave_energy.py:34 msgid "Index of this percentile bin." -msgstr "" +msgstr "此百分点箱的索引。" #: src/natcap/invest/wave_energy.py:38 msgid "Percentile range within this bin." -msgstr "" +msgstr "此框内的百分比范围。" #: src/natcap/invest/wave_energy.py:42 msgid "Number of pixels whose wave energy values fall into this percentile bin." -msgstr "" +msgstr "波能量值落在此百分位范围内的像素数。" #: src/natcap/invest/wave_energy.py:51 src/natcap/invest/wind_energy.py:331 msgid "Unique identifier for each point." @@ -2847,9 +2416,7 @@ msgid "Global WaveWatchIII data." msgstr "全球WaveWatchIII数据。" #: src/natcap/invest/wave_energy.py:244 -msgid "" -"Pre-packaged wave energy data directory. This is provided with the sample" -" data." +msgid "Pre-packaged wave energy data directory. This is provided with the sample data." msgstr "预先打包的波浪能数据目录。这是与样本数据一起提供的。" #: src/natcap/invest/wave_energy.py:247 @@ -2890,15 +2457,13 @@ msgstr "研究区" #: src/natcap/invest/wave_energy.py:275 msgid "" -"A matrix of the wave machine performance, or ability to capture wave " -"energy, in different sea state conditions. The first column contains wave" -" height values (in meters, increasing from top to bottom), and the first " -"row contains wave period values (in seconds, increasing from left to " -"right). Values within the matrix are the machine performance in kilowatts" -" at that sea state condition, described by the wave height (row) and wave" -" period (column). The model linearly interpolates sea state data from the" -" base wave dataset onto this matrix to determine performance." -msgstr "波浪机在不同海况条件下的性能,或捕捉波浪能量的能力的矩阵。第一列包含波高值(米,从上到下增加),第一行包含波周期值(秒,从左到右增加)。矩阵内的数值是在该海况下的机器性能,单位是千瓦,由波高(行)和波期(列)描述。该模型将基本波浪数据集的海况数据线性内插到该矩阵上,以确定性能。" +"A matrix of the wave machine performance, or ability to capture wave energy, in different sea state conditions. The first column contains wave height values (in " +"meters, increasing from top to bottom), and the first row contains wave period values (in seconds, increasing from left to right). Values within the matrix are the " +"machine performance in kilowatts at that sea state condition, described by the wave height (row) and wave period (column). The model linearly interpolates sea state " +"data from the base wave dataset onto this matrix to determine performance." +msgstr "" +"波浪机在不同海况条件下的性能,或捕捉波浪能量的能力的矩阵。第一列包含波高值(米,从上到下增加),第一行包含波周期值(秒,从左到右增加)。矩阵内的数值是在该海况下的机器性" +"能,单位是千瓦,由波高(行)和波期(列)描述。该模型将基本波浪数据集的海况数据线性内插到该矩阵上,以确定性能。" #: src/natcap/invest/wave_energy.py:286 msgid "machine performance table" @@ -2906,16 +2471,13 @@ msgstr "机器性能表" #: src/natcap/invest/wave_energy.py:295 msgid "" -"Name of the machine parameter. Expected parameters are: 'capmax' (maximum" -" capacity for device, in kilowatts), 'hsmax' (upper limit of wave height " -"for device operation, in meters), and 'tpmax' (upper limit of wave period" -" for device operation, in seconds)." -msgstr "" +"Name of the machine parameter. Expected parameters are: 'capmax' (maximum capacity for device, in kilowatts), 'hsmax' (upper limit of wave height for device operation, " +"in meters), and 'tpmax' (upper limit of wave period for device operation, in seconds)." +msgstr "机器参数的名称。预期参数为:“capmax”(设备的最大容量,单位为千瓦)、“hsmax”(设备运行的波高上限,单位为米)和“tpmax”(设备运行的波周期上限,单位为秒)。" #: src/natcap/invest/wave_energy.py:305 src/natcap/invest/wave_energy.py:354 -#, fuzzy msgid "Value of the machine parameter." -msgstr "机器参数表" +msgstr "机器参数的值。" #: src/natcap/invest/wave_energy.py:308 msgid "Table of parameters for the wave energy machine in use." @@ -2933,21 +2495,17 @@ msgstr "测深学" msgid "Map of ocean depth. Values should be negative." msgstr "海洋深度的地图。数值应该是负的。" -#: src/natcap/invest/scenic_quality/scenic_quality.py:121 -#: src/natcap/invest/wave_energy.py:320 +#: src/natcap/invest/scenic_quality/scenic_quality.py:121 src/natcap/invest/wave_energy.py:320 msgid "Run the valuation model." msgstr "运行估值模型。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:353 -#: src/natcap/invest/scenic_quality/scenic_quality.py:118 -#: src/natcap/invest/wave_energy.py:321 src/natcap/invest/wind_energy.py:310 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:353 src/natcap/invest/scenic_quality/scenic_quality.py:118 src/natcap/invest/wave_energy.py:321 +#: src/natcap/invest/wind_energy.py:310 msgid "run valuation" msgstr "运行估值模型" #: src/natcap/invest/wave_energy.py:327 -msgid "" -"A table of data for each connection point. Required if Run Valuation is " -"selected." +msgid "A table of data for each connection point. Required if Run Valuation is selected." msgstr "每个连接点的数据表格。如果选择运行估值,则需要。" #: src/natcap/invest/wave_energy.py:330 @@ -2956,20 +2514,16 @@ msgstr "电网连接点表" #: src/natcap/invest/wave_energy.py:339 msgid "" -"Name of the machine parameter. Expected parameters are: 'capmax' (maximum" -" capacity for device, in kilowatts), 'cc' (capital cost per device " -"installed, $/kilowatt), 'cml' (cost of mooring lines, $/kilometer), 'cul'" -" (cost of underwater cable, $/kilometer), 'col' (cost of overland " -"transmission lines, $/kilometer), 'omc' (operating and maintenance cost, " -"$/kilowatt hour), 'p' (price of electricity, $/kilowatt hour), 'r' " -"(discount rate, between 0 and 1), 'smlpm' (number of slack lines required" -" per machine)" +"Name of the machine parameter. Expected parameters are: 'capmax' (maximum capacity for device, in kilowatts), 'cc' (capital cost per device installed, $/kilowatt), " +"'cml' (cost of mooring lines, $/kilometer), 'cul' (cost of underwater cable, $/kilometer), 'col' (cost of overland transmission lines, $/kilometer), 'omc' (operating " +"and maintenance cost, $/kilowatt hour), 'p' (price of electricity, $/kilowatt hour), 'r' (discount rate, between 0 and 1), 'smlpm' (number of slack lines required per " +"machine)" msgstr "" +"机器参数的名称。预期参数为:“capmax”(设备最大容量,单位千瓦)、“cc”(每台安装设备的资本成本,美元/千瓦)、“cml”(系泊线成本,美元/千米)、“cul”(水下电缆成本,美元/千" +"米)、“col”(陆上输电线成本,美元/千米)、“omc”(运行和维护成本,美元/千瓦时)、“p”(电价,美元/千瓦时)、“r”(贴现率,0到1之间)、“smlpm”(每台机器所需的松弛线数量)" #: src/natcap/invest/wave_energy.py:358 -msgid "" -"Table of economic parameters for the wave energy machine. Required if Run" -" Valuation is selected." +msgid "Table of economic parameters for the wave energy machine. Required if Run Valuation is selected." msgstr "波浪能机器的经济参数表。如果选择运行评估,则需要。" #: src/natcap/invest/wave_energy.py:361 @@ -2986,74 +2540,61 @@ msgstr "机器数量" #: src/natcap/invest/wave_energy.py:379 msgid "Map of captured wave energy per WEC device." -msgstr "" +msgstr "每个WEC设备捕获的波能图。" #: src/natcap/invest/wave_energy.py:387 -msgid "" -"Map of captured wave energy per WEC device reclassified by quantiles (1 =" -" < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." -msgstr "" +msgid "Map of captured wave energy per WEC device reclassified by quantiles (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +msgstr "按分位数重新分类的每个WEC设备捕获的波能量图(1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)。" #: src/natcap/invest/wave_energy.py:394 -msgid "" -"Table of value ranges for each captured wave energy quantile group as " -"well as the number of pixels for each group." -msgstr "" +msgid "Table of value ranges for each captured wave energy quantile group as well as the number of pixels for each group." +msgstr "每个捕获的波能量分位数组的值范围以及每个组的像素数的表。" #: src/natcap/invest/wave_energy.py:404 msgid "Range of wave energy values within this percentile bin." -msgstr "" +msgstr "该百分位范围内的波能量值范围。" #: src/natcap/invest/wave_energy.py:412 msgid "Vector map of the provided grid points" -msgstr "" +msgstr "所提供网格点的矢量地图" #: src/natcap/invest/wave_energy.py:418 msgid "Vector map of the provided land points" -msgstr "" +msgstr "所提供的陆地点的矢量地图" #: src/natcap/invest/wave_energy.py:423 msgid "" -"Map of positive values of net present value over the 25-year lifespan of " -"a wave energy facility, reclassified by quantiles (1 = < 25%, 2 = 25-50%," -" 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." -msgstr "" +"Map of positive values of net present value over the 25-year lifespan of a wave energy facility, reclassified by quantiles (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = " +"75-90%, 5 = > 90%)." +msgstr "波浪能发电设施25年寿命期间净现值的正值图,按分位数重新分类 (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)。" #: src/natcap/invest/wave_energy.py:431 -msgid "" -"Table of value ranges for each net present value quantile group as well " -"as the number of pixels for each group." -msgstr "" +msgid "Table of value ranges for each net present value quantile group as well as the number of pixels for each group." +msgstr "每个净现值分位数组的值范围表以及每个组的像素数。" #: src/natcap/invest/wave_energy.py:441 msgid "Range of net present values within this percentile bin." -msgstr "" +msgstr "该百分位数区间内的净现值范围。" #: src/natcap/invest/wave_energy.py:448 -msgid "" -"Map of net present value over the 25-year lifespan of a wave energy " -"facility." -msgstr "" +msgid "Map of net present value over the 25-year lifespan of a wave energy facility." +msgstr "波浪能设施 25 年寿命期的净现值图。" #: src/natcap/invest/wave_energy.py:457 msgid "Map of potential wave power." -msgstr "" +msgstr "潜在波浪能地图。" #: src/natcap/invest/wave_energy.py:464 -msgid "" -"Map of potential wave power classified into quantiles (1 = < 25%, 2 = " -"25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." -msgstr "" +msgid "Map of potential wave power classified into quantiles (1 = < 25%, 2 = 25-50%, 3 = 50-75%, 4 = 75-90%, 5 = > 90%)." +msgstr "潜在波浪功率分布图(1 = <25%,2 = 25-50%,3 = 50-75%,4 = 75-90%,5 = >90%)。" #: src/natcap/invest/wave_energy.py:471 -msgid "" -"Table of value ranges for each wave power quantile group as well as the " -"number of pixels for each group." -msgstr "" +msgid "Table of value ranges for each wave power quantile group as well as the number of pixels for each group." +msgstr "每组波功率量级的数值范围以及每组的像素数量表。" #: src/natcap/invest/wave_energy.py:480 msgid "Range of potential wave power values within this percentile bin." -msgstr "" +msgstr "该百分位数区间内的潜在波浪功率值范围。" #: src/natcap/invest/wind_energy.py:36 msgid "Longitude of the data point." @@ -3072,24 +2613,20 @@ msgid "Weibull shape factor at this point." msgstr "在这一点上,Weibull形状因子。" #: src/natcap/invest/wind_energy.py:58 -msgid "" -"The reference hub height at this point, at which wind speed data was " -"collected and LAM was estimated." +msgid "The reference hub height at this point, at which wind speed data was collected and LAM was estimated." msgstr "在这一点上的参考枢纽高度,在这一点上收集风速数据并估计LAM。" #: src/natcap/invest/wind_energy.py:69 -#, fuzzy msgid "Weibull scale factor calculated for the proposed hub height at this point." -msgstr "在这一点上,参考枢纽高度的Weibull比例因子。" +msgstr "为该点的拟议轮毂高度计算的 Weibull 比例系数。" #: src/natcap/invest/wind_energy.py:83 -#, fuzzy msgid "Power density at this point." -msgstr "在这一点上,Weibull形状因子。" +msgstr "此时的功率密度。" #: src/natcap/invest/wind_energy.py:88 msgid "Predicted energy harvested from a wind farm centered on this point." -msgstr "" +msgstr "以该点为中心的风力发电场的预测能量。" #: src/natcap/invest/wind_energy.py:110 msgid "Table of Weibull parameters for each wind data point." @@ -3101,15 +2638,12 @@ msgstr "风数据点" #: src/natcap/invest/wind_energy.py:118 msgid "" -"Map of the area(s) of interest over which to run the model and aggregate " -"valuation results. Required if Run Valuation is selected and the Grid " -"Connection Points table is provided." +"Map of the area(s) of interest over which to run the model and aggregate valuation results. Required if Run Valuation is selected and the Grid Connection Points table " +"is provided." msgstr "运行模型和汇总估价结果的相关区域地图。如果选择了运行评估并提供了网格连接点表格,则需要。" #: src/natcap/invest/wind_energy.py:135 -msgid "" -"Map of the coastlines of landmasses in the area of interest. Required if " -"the Minimum Distance and Maximum Distance inputs are provided." +msgid "Map of the coastlines of landmasses in the area of interest. Required if the Minimum Distance and Maximum Distance inputs are provided." msgstr "感兴趣的地区的陆地的海岸线地图。如果提供最小距离和最大距离的输入,则需要。" #: src/natcap/invest/wind_energy.py:139 @@ -3125,9 +2659,7 @@ msgid "Exponent to use in the power curve function." msgstr "功率曲线函数中使用的指数。" #: src/natcap/invest/wind_energy.py:154 -msgid "" -"Cost to decommission a turbine as a proportion of the total upfront costs" -" (cables, foundations, installation?)" +msgid "Cost to decommission a turbine as a proportion of the total upfront costs (cables, foundations, installation?)" msgstr "涡轮机退役的成本占前期总成本的比例(电缆、地基、安装?)" #: src/natcap/invest/wind_energy.py:161 @@ -3168,9 +2700,7 @@ msgstr "与长度成比例的直流电缆的成本。" #: src/natcap/invest/wind_energy.py:201 msgid "" -"The threshold above which a wind farm’s distance from the grid requires a" -" switch from AC to DC power to overcome line losses which reduce the " -"amount of energy delivered" +"The threshold above which a wind farm’s distance from the grid requires a switch from AC to DC power to overcome line losses which reduce the amount of energy delivered" msgstr "风电场与电网的距离超过这个阈值时,需要从交流电转换为直流电,以克服线路损耗,从而减少输送的能量" #: src/natcap/invest/wind_energy.py:209 @@ -3178,9 +2708,7 @@ msgid "The expected lifetime of the facility" msgstr "设施的预期寿命" #: src/natcap/invest/wind_energy.py:213 -msgid "" -"Factor that translates carbon-free wind power to a corresponding amount " -"of avoided CO2 emissions" +msgid "Factor that translates carbon-free wind power to a corresponding amount of avoided CO2 emissions" msgstr "将无碳的风力发电转化为相应的避免的二氧化碳排放量的因素" #: src/natcap/invest/wind_energy.py:219 @@ -3188,9 +2716,7 @@ msgid "The reduction in air density per meter above sea level" msgstr "海平面以上每米的空气密度减少量" #: src/natcap/invest/wind_energy.py:224 -msgid "" -"The fraction of energy lost due to downtime, power conversion " -"inefficiency, and electrical grid losses" +msgid "The fraction of energy lost due to downtime, power conversion inefficiency, and electrical grid losses" msgstr "由于停机、电力转换效率低下和电网损失而损失的能源部分" #: src/natcap/invest/wind_energy.py:228 @@ -3214,9 +2740,7 @@ msgid "Minimum wind speed at which the turbine reaches its rated power output." msgstr "涡轮机达到额定输出功率的最低风速。" #: src/natcap/invest/wind_energy.py:254 -msgid "" -"Wind speed above which the turbine stops generating power for safety " -"reasons." +msgid "Wind speed above which the turbine stops generating power for safety reasons." msgstr "风速,超过这个风速,涡轮机就会出于安全原因停止发电。" #: src/natcap/invest/wind_energy.py:260 @@ -3260,9 +2784,7 @@ msgid "maximum depth" msgstr "最大深度" #: src/natcap/invest/wind_energy.py:292 -msgid "" -"Minimum distance from shore for offshore wind farm installation. Required" -" if Run Valuation is selected." +msgid "Minimum distance from shore for offshore wind farm installation. Required if Run Valuation is selected." msgstr "海上风电场安装的最小离岸距离。如果选择运行评估,则需要。" #: src/natcap/invest/wind_energy.py:295 @@ -3270,9 +2792,7 @@ msgid "minimum distance" msgstr "最小距离" #: src/natcap/invest/wind_energy.py:301 -msgid "" -"Maximum distance from shore for offshore wind farm installation. Required" -" if Run Valuation is selected." +msgid "Maximum distance from shore for offshore wind farm installation. Required if Run Valuation is selected." msgstr "海上风电场安装的最大离岸距离。如果选择运行评估,则需要。" #: src/natcap/invest/wind_energy.py:304 @@ -3295,16 +2815,12 @@ msgstr "基础费用" msgid "Annual discount rate to apply to valuation." msgstr "适用于估价的年度贴现率。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:408 -#: src/natcap/invest/wind_energy.py:323 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:408 src/natcap/invest/wind_energy.py:323 msgid "discount rate" msgstr "折现率" #: src/natcap/invest/wind_energy.py:354 -msgid "" -"Table of grid and land connection points to which cables will connect. " -"Required if Run Valuation is selected and Average Shore-to-Grid Distance " -"is not provided." +msgid "Table of grid and land connection points to which cables will connect. Required if Run Valuation is selected and Average Shore-to-Grid Distance is not provided." msgstr "电缆将连接的电网和陆地连接点的表格。如果选择了运行评估,并且没有提供海岸到网格的平均距离,则需要。" #: src/natcap/invest/wind_energy.py:358 @@ -3313,9 +2829,7 @@ msgstr "电网连接点表" #: src/natcap/invest/wind_energy.py:365 msgid "" -"Average distance to the onshore grid from coastal cable landing points. " -"Required if Run Valuation is selected and the Grid Connection Points " -"table is not provided." +"Average distance to the onshore grid from coastal cable landing points. Required if Run Valuation is selected and the Grid Connection Points table is not provided." msgstr "从沿海电缆登陆点到陆上电网的平均距离。如果选择运行评估,且未提供电网连接点表,则需要。" #: src/natcap/invest/wind_energy.py:369 @@ -3323,21 +2837,17 @@ msgid "average shore-to-grid distance" msgstr "岸边到电网的平均距离" #: src/natcap/invest/wind_energy.py:374 -msgid "" -"Use a Wind Energy Price Table instead of calculating annual prices from " -"the initial Energy Price and Rate of Price Change inputs." +msgid "Use a Wind Energy Price Table instead of calculating annual prices from the initial Energy Price and Rate of Price Change inputs." msgstr "使用风能价格表,而不是从最初的能源价格和价格变化率输入来计算年度价格。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:362 -#: src/natcap/invest/wind_energy.py:378 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:362 src/natcap/invest/wind_energy.py:378 msgid "use price table" msgstr "使用价格表" #: src/natcap/invest/wind_energy.py:387 msgid "" -"Consecutive years for each year in the lifespan of the wind farm. These " -"may be the actual years: 2010, 2011, 2012..., or the number of the years " -"after the starting date: 1, 2, 3,..." +"Consecutive years for each year in the lifespan of the wind farm. These may be the actual years: 2010, 2011, 2012..., or the number of the years after the starting " +"date: 1, 2, 3,..." msgstr "风电场寿命期中每一年的连续年份。这些可以是实际年份:2010年、2011年、2012年......,也可以是起始日期之后的年份:1、2、3......。" #: src/natcap/invest/wind_energy.py:396 @@ -3346,10 +2856,8 @@ msgstr "每一年的能源价格。" #: src/natcap/invest/wind_energy.py:400 msgid "" -"Table of yearly prices for wind energy. There must be a row for each year" -" in the lifespan given in the 'time_period' column in the Global Wind " -"Energy Parameters table. Required if Run Valuation and Use Price Table " -"are selected." +"Table of yearly prices for wind energy. There must be a row for each year in the lifespan given in the 'time_period' column in the Global Wind Energy Parameters table. " +"Required if Run Valuation and Use Price Table are selected." msgstr "风力发电的年度价格表。在全球风能参数表的'时间_周期'栏中给出的寿命期内,每年必须有一行。如果选择了运行估值和使用价格表,则需要。" #: src/natcap/invest/wind_energy.py:405 @@ -3357,10 +2865,7 @@ msgid "wind energy price table" msgstr "风能价格表" #: src/natcap/invest/wind_energy.py:411 -msgid "" -"The initial price of wind energy, at the first year in the wind energy " -"farm lifespan. Required if Run Valuation is selected and Use Price Table " -"is not selected." +msgid "The initial price of wind energy, at the first year in the wind energy farm lifespan. Required if Run Valuation is selected and Use Price Table is not selected." msgstr "风力发电场寿命中第一年的风能初始价格。如果选择了运行评估和不选择使用价格表,则需要。" #: src/natcap/invest/wind_energy.py:415 @@ -3368,9 +2873,7 @@ msgid "price of energy" msgstr "能源价格" #: src/natcap/invest/wind_energy.py:420 -msgid "" -"The annual rate of change in the price of wind energy. Required if Run " -"Valuation is selected and Use Price Table is not selected." +msgid "The annual rate of change in the price of wind energy. Required if Run Valuation is selected and Use Price Table is not selected." msgstr "风能价格的年变化率。如果选择了运行估价和不选择使用价格表,则需要。" #: src/natcap/invest/wind_energy.py:424 @@ -3379,34 +2882,30 @@ msgstr "价格变化率" #: src/natcap/invest/wind_energy.py:432 msgid "Map of offset carbon emissions for a farm centered on each pixel" -msgstr "" +msgstr "每个像素点为中心的农场抵消碳排放的地图" #: src/natcap/invest/wind_energy.py:441 msgid "Map of power density." -msgstr "" +msgstr "功率密度地图。" #: src/natcap/invest/wind_energy.py:448 msgid "Map of energy harvested from a farm centered on each pixel." -msgstr "" +msgstr "以每个像素点为中心的农场收获的能量地图。" #: src/natcap/invest/wind_energy.py:456 -msgid "" -"Map of the energy price that would be required to set the present value " -"of a farm centered on each pixel equal to zero." -msgstr "" +msgid "Map of the energy price that would be required to set the present value of a farm centered on each pixel equal to zero." +msgstr "以每个像素点为中心的农场使其现值为零所需的能源价格地图。" #: src/natcap/invest/wind_energy.py:466 msgid "Map of the net present value of a farm centered on each pixel." -msgstr "" +msgstr "以每个像素点为中心的农场净现值地图。" #: src/natcap/invest/wind_energy.py:471 msgid "Map of summarized data at each point." -msgstr "" +msgstr "每个点的总结数据地图。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:116 -msgid "" -"Analysis year {analysis_year} must be >= the latest snapshot year " -"({latest_year})" +msgid "Analysis year {analysis_year} must be >= the latest snapshot year ({latest_year})" msgstr "分析年份{analysis_year}必须>=最新快照年份({latest_year})" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:119 @@ -3414,22 +2913,15 @@ msgid "Raster for snapshot {snapshot_year} could not be validated." msgstr "快照{snapshot_year}的栅格不能被验证。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:121 -msgid "" -"The transition table expects values of {model_transitions} but found " -"values of {transition_values}." -msgstr "" +msgid "The transition table expects values of {model_transitions} but found values of {transition_values}." +msgstr "转换表期望值为{model_transitions},但发现值为{transition_values}。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:177 -msgid "" -"The snapshot year that this row's LULC raster represents. Each year in " -"this table must be unique." +msgid "The snapshot year that this row's LULC raster represents. Each year in this table must be unique." msgstr "这一行的LULC栅格所代表的快照年份。此表中的每一年必须是唯一的。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:184 -msgid "" -"Map of LULC in the given snapshot year. All values in this raster must " -"have corresponding entries in the Biophysical Table and Landcover " -"Transitions Table." +msgid "Map of LULC in the given snapshot year. All values in this raster must have corresponding entries in the Biophysical Table and Landcover Transitions Table." msgstr "在给定的快照年份,LULC的地图。该栅格中的所有数值必须在生物物理表和土地覆被转换表中有相应的条目。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:191 @@ -3446,22 +2938,16 @@ msgstr "分析年" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:200 msgid "" -"A year that may be used to extend the analysis beyond the last snapshot " -"year. If used, the model assumes that carbon will continue to accumulate " -"or emit after the last snapshot year until the analysis year. This value " -"must be greater than the final snapshot year." +"A year that may be used to extend the analysis beyond the last snapshot year. If used, the model assumes that carbon will continue to accumulate or emit after the last " +"snapshot year until the analysis year. This value must be greater than the final snapshot year." msgstr "一个可用于将分析延伸到最后一个快照年之后的年份。如果使用,模型假定碳在最后一个快照年之后将继续积累或排放,直到分析年。该值必须大于最后快照年。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:214 -msgid "" -"The LULC code that represents this LULC class in the LULC snapshot " -"rasters." +msgid "The LULC code that represents this LULC class in the LULC snapshot rasters." msgstr "在LULC快照栅格中代表该LULC类别的LULC代码。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:219 -msgid "" -"Name of the LULC class. This label must be unique among the all the LULC " -"classes." +msgid "Name of the LULC class. This label must be unique among the all the LULC classes." msgstr "LULC类别的名称。这个标签在所有LULC等级中必须是唯一的。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:225 @@ -3481,22 +2967,15 @@ msgid "The half-life of carbon in the biomass pool." msgstr "碳在生物质库中的半衰期。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:247 -msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a " -"cell transitions away from this LULC class in a low-impact disturbance." +msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a low-impact disturbance." msgstr "当一个单元在低影响的干扰下从该LULC等级过渡到其他等级时,生物量池中碳储量的比例受到干扰。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:253 -msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a " -"cell transitions away from this LULC class in a medium-impact " -"disturbance." +msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a medium-impact disturbance." msgstr "在中等影响的干扰下,当一个单元从该LULC等级过渡到其他等级时,生物量池中碳储量的比例受到干扰。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:259 -msgid "" -"Proportion of carbon stock in the biomass pool that is disturbed when a " -"cell transitions away from this LULC class in a high-impact disturbance." +msgid "Proportion of carbon stock in the biomass pool that is disturbed when a cell transitions away from this LULC class in a high-impact disturbance." msgstr "当一个单元在高影响扰动下从该LULC等级过渡到其他等级时,生物量池中碳储量的比例受到干扰。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:266 @@ -3508,21 +2987,15 @@ msgid "The half-life of carbon in the soil pool." msgstr "土壤池中的碳的半衰期。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:275 -msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell" -" transitions away from this LULC class in a low-impact disturbance." +msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a low-impact disturbance." msgstr "当一个单元在低影响的干扰中脱离该LULC等级时,土壤池中碳储量的比例受到干扰。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:281 -msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell" -" transitions away from this LULC class in a medium-impact disturbance." +msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a medium-impact disturbance." msgstr "在中等影响的干扰下,当一个单元从该LULC等级过渡到其他等级时,土壤池中的碳储量比例受到干扰。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:287 -msgid "" -"Proportion of carbon stock in the soil pool that is disturbed when a cell" -" transitions away from this LULC class in a high-impact disturbance." +msgid "Proportion of carbon stock in the soil pool that is disturbed when a cell transitions away from this LULC class in a high-impact disturbance." msgstr "当一个单元在高影响的干扰中从该LULC等级过渡到其他等级时,土壤池中的碳储量比例受到干扰。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:294 @@ -3542,12 +3015,10 @@ msgid "landcover transitions table" msgstr "土地覆盖转换表" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:311 -#, fuzzy msgid "LULC class names matching those in the biophysical table." -msgstr "LULC代码与生物物理表中的代码相匹配。" +msgstr "土地利用/土地覆盖类别名称与生物物理表中的类别匹配。" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:318 -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:97 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:318 src/natcap/invest/coastal_blue_carbon/preprocessor.py:97 msgid "a state of carbon accumulation" msgstr "积碳状态" @@ -3563,44 +3034,31 @@ msgstr "中等碳扰动率" msgid "low carbon disturbance rate" msgstr "低碳扰动率" -#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:330 -#: src/natcap/invest/coastal_blue_carbon/preprocessor.py:106 +#: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:330 src/natcap/invest/coastal_blue_carbon/preprocessor.py:106 msgid "no change in carbon" msgstr "碳无变化" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:333 msgid "" -"A transition matrix describing the type of carbon action that occurs when" -" each LULC type transitions to each other type. Values in the first " -"column, 'lulc-class', represents the original LULC class that is " -"transitioned away from. Values in the first row represents the LULC class" -" that is transitioned to. Each cell in the matrix is filled with an " -"option indicating the effect on carbon when transitioning from that " -"cell's row's LULC class to that cell's column's LULC class. The classes " -"in this table must exactly match the classes in the Biophysical Table " -"'lulc-class' column. A cell may be left empty if the transition never " -"occurs." +"A transition matrix describing the type of carbon action that occurs when each LULC type transitions to each other type. Values in the first column, 'lulc-class', " +"represents the original LULC class that is transitioned away from. Values in the first row represents the LULC class that is transitioned to. Each cell in the matrix " +"is filled with an option indicating the effect on carbon when transitioning from that cell's row's LULC class to that cell's column's LULC class. The classes in this " +"table must exactly match the classes in the Biophysical Table 'lulc-class' column. A cell may be left empty if the transition never occurs." msgstr "" -"一个过渡矩阵,描述每个LULC类型过渡到其他类型时发生的碳行动的类型。第一列中的数值,\"LULC-" -"class\",代表被过渡到的原始LULC类别。第一行中的数值代表被过渡到的LULC类别。矩阵中的每个单元格都填有一个选项,表示从该单元格的行的LULC等级过渡到该单元格的列的LULC等级时对碳的影响。该表中的等级必须与生物物理表" -" \"LULC-Class \"列中的等级完全一致。如果转换从未发生,则单元格可以留空。" +"一个过渡矩阵,描述每个LULC类型过渡到其他类型时发生的碳行动的类型。第一列中的数值,\"LULC-class\",代表被过渡到的原始LULC类别。第一行中的数值代表被过渡到的LULC类别。矩阵" +"中的每个单元格都填有一个选项,表示从该单元格的行的LULC等级过渡到该单元格的列的LULC等级时对碳的影响。该表中的等级必须与生物物理表 \"LULC-Class \"列中的等级完全一致。如果" +"转换从未发生,则单元格可以留空。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:348 -msgid "" -"A transition matrix mapping the type of carbon action undergone when one " -"LULC type transitions to another." +msgid "A transition matrix mapping the type of carbon action undergone when one LULC type transitions to another." msgstr "当一种LULC类型过渡到另一种LULC类型时,一个过渡矩阵映射出所经历的碳行动的类型。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:356 -msgid "" -"Enable net present valuation analysis based on carbon prices from either " -"a yearly price table, or an initial price and yearly interest rate." +msgid "Enable net present valuation analysis based on carbon prices from either a yearly price table, or an initial price and yearly interest rate." msgstr "启用基于年度价格表的碳价格,或初始价格和年度利率的净现值分析。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:365 -msgid "" -"Use a yearly price table, rather than an initial price and interest rate," -" to indicate carbon value over time." +msgid "Use a yearly price table, rather than an initial price and interest rate, to indicate carbon value over time." msgstr "使用年度价格表,而不是初始价格和利率,以表明随着时间推移的碳价值。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:370 @@ -3608,9 +3066,7 @@ msgid "price" msgstr "价格" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:374 -msgid "" -"The price of CO2E at the baseline year. Required if Do Valuation is " -"selected and Use Price Table is not selected." +msgid "The price of CO2E at the baseline year. Required if Do Valuation is selected and Use Price Table is not selected." msgstr "基线年的CO2E价格。如果选择 \"做估值 \"且不选择 \"使用价格表\",则需要。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:379 @@ -3618,9 +3074,7 @@ msgid "interest rate" msgstr "利率" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:382 -msgid "" -"Annual increase in the price of CO2E. Required if Do Valuation is " -"selected and Use Price Table is not selected." +msgid "Annual increase in the price of CO2E. Required if Do Valuation is selected and Use Price Table is not selected." msgstr "CO2E价格的年度增长。如果选择 \"做估值 \"且不选择 \"使用价格表\",则需要。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:387 @@ -3637,15 +3091,12 @@ msgstr "当年的CO2E价格。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:402 msgid "" -"Table of annual CO2E prices for each year from the baseline year to the " -"final snapshot or analysis year. Required if Do Valuation is selected and" -" Use Price Table is selected." +"Table of annual CO2E prices for each year from the baseline year to the final snapshot or analysis year. Required if Do Valuation is selected and Use Price Table is " +"selected." msgstr "从基线年到最终快照或分析年每年的CO2E价格表。如果选择 \"做估值 \"并选择 \"使用价格表\",则需要。" #: src/natcap/invest/coastal_blue_carbon/coastal_blue_carbon.py:411 -msgid "" -"Annual discount rate on the price of carbon. This is compounded each year" -" after the baseline year. Required if Run Valuation is selected." +msgid "Annual discount rate on the price of carbon. This is compounded each year after the baseline year. Required if Run Valuation is selected." msgstr "碳价格的年度折扣率。在基线年之后每年复利。如果选择运行评估,则需要。" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:33 @@ -3653,16 +3104,11 @@ msgid "LULC lookup table" msgstr "LULC查询表" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:35 -msgid "" -"A table mapping LULC codes from the snapshot rasters to the corresponding" -" LULC class names, and whether or not the class is a coastal blue carbon " -"habitat." +msgid "A table mapping LULC codes from the snapshot rasters to the corresponding LULC class names, and whether or not the class is a coastal blue carbon habitat." msgstr "将快照栅格中的LULC代码映射到相应的LULC等级名称,以及该等级是否为沿海蓝碳生境的表格。" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:43 -msgid "" -"LULC code. Every value in the snapshot LULC maps must have a " -"corresponding entry in this column." +msgid "LULC code. Every value in the snapshot LULC maps must have a corresponding entry in this column." msgstr "LULC代码。在快照LULC地图中的每一个值都必须在这一栏中有一个相应的条目。" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:49 @@ -3670,9 +3116,7 @@ msgid "Name of the LULC class." msgstr "LULC等级的名称。" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:52 -msgid "" -"Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if " -"not." +msgid "Enter TRUE if this LULC class is a coastal blue carbon habitat, FALSE if not." msgstr "如果该LULC类别是沿海蓝碳生境,则输入TRUE,如果不是,则输入FALSE。" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:63 @@ -3680,9 +3124,7 @@ msgid "Year to snapshot." msgstr "年到快照。" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:67 -msgid "" -"Map of LULC in the snapshot year. All values in this raster must have " -"corresponding entries in the LULC Lookup table." +msgid "Map of LULC in the snapshot year. All values in this raster must have corresponding entries in the LULC Lookup table." msgstr "快照年份的LULC地图。该栅格中的所有数值必须在LULC查询表中有相应的条目。" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:73 @@ -3698,16 +3140,11 @@ msgid "LULC codes matching the codes in the biophysical table." msgstr "LULC代码与生物物理表中的代码相匹配。" #: src/natcap/invest/coastal_blue_carbon/preprocessor.py:100 -msgid "" -"Carbon disturbance occurred. Replace this with one of ‘low-impact-" -"disturb’, ‘med-impact-disturb’, or ‘high-impact-disturb’ to indicate the " -"degree of disturbance." -msgstr "" +msgid "Carbon disturbance occurred. Replace this with one of ‘low-impact-disturb’, ‘med-impact-disturb’, or ‘high-impact-disturb’ to indicate the degree of disturbance." +msgstr "发生了碳扰动。将其替换为以下之一:'low-impact-disturb'(低影响扰动)、'med-impact-disturb'(中等影响扰动)或'high-impact-disturb'(高影响扰动),以指示扰动程度。" #: src/natcap/invest/delineateit/delineateit.py:46 -msgid "" -"Detect pour points (watershed outlets) based on the DEM, and use these " -"instead of a user-provided outlet features vector." +msgid "Detect pour points (watershed outlets) based on the DEM, and use these instead of a user-provided outlet features vector." msgstr "根据DEM检测倾倒点(流域出口),并使用这些倾倒点而不是用户提供的出口特征矢量。" #: src/natcap/invest/delineateit/delineateit.py:50 @@ -3715,9 +3152,7 @@ msgid "detect pour points" msgstr "检测倾倒点" #: src/natcap/invest/delineateit/delineateit.py:57 -msgid "" -"A map of watershed outlets from which to delineate the watersheds. " -"Required if Detect Pour Points is not checked." +msgid "A map of watershed outlets from which to delineate the watersheds. Required if Detect Pour Points is not checked." msgstr "流域出口的地图,据此划定流域。如果没有勾选检测倾倒点,则需要。" #: src/natcap/invest/delineateit/delineateit.py:60 @@ -3726,15 +3161,12 @@ msgstr "流域出口" #: src/natcap/invest/delineateit/delineateit.py:65 msgid "" -"Whether to snap point geometries to the nearest stream pixel. If " -"``True``, ``args['flow_threshold']`` and ``args['snap_distance']`` must " -"also be defined. If a point is equally near to more than one stream " -"pixel, it will be snapped to the stream pixel with the highest flow " -"accumulation value. This has no effect if Detect Pour Points is selected." +"Whether to snap point geometries to the nearest stream pixel. If ``True``, ``args['flow_threshold']`` and ``args['snap_distance']`` must also be defined. If a point " +"is equally near to more than one stream pixel, it will be snapped to the stream pixel with the highest flow accumulation value. This has no effect if Detect Pour " +"Points is selected." msgstr "" -"是否将点的几何图形抓取到最近的河流栅格。 如果是 \"True\",还必须定义 \"args['flow_threshold']\"和 " -"\"args['snap_distance''\"。如果一个点同样靠近一个以上的河流栅格,它将被捕捉到具有最高流量累积值的河流栅格。如果选择了Detect" -" Pour Points,这就没有影响。" +"是否将点的几何图形抓取到最近的河流栅格。 如果是 \"True\",还必须定义 \"args['flow_threshold']\"和 \"args['snap_distance''\"。如果一个点同样靠近一个以上的河流栅格,它将" +"被捕捉到具有最高流量累积值的河流栅格。如果选择了Detect Pour Points,这就没有影响。" #: src/natcap/invest/delineateit/delineateit.py:73 msgid "snap points to the nearest stream" @@ -3745,9 +3177,7 @@ msgid "about Required if Snap Points is selected." msgstr "如果选择了Snap Points,则需要。" #: src/natcap/invest/delineateit/delineateit.py:87 -msgid "" -"Maximum distance to relocate watershed outlet points in order to snap " -"them to a stream. Required if Snap Points is selected." +msgid "Maximum distance to relocate watershed outlet points in order to snap them to a stream. Required if Snap Points is selected." msgstr "重新定位流域出口点的最大距离,以便将其锁定在一个流上。如果选择卡住点,则需要。" #: src/natcap/invest/delineateit/delineateit.py:91 @@ -3755,9 +3185,7 @@ msgid "snap distance" msgstr "捕捉距离" #: src/natcap/invest/delineateit/delineateit.py:96 -msgid "" -"Skip delineation for any invalid geometries found in the Outlet Features." -" Otherwise, an invalid geometry will cause the model to crash." +msgid "Skip delineation for any invalid geometries found in the Outlet Features. Otherwise, an invalid geometry will cause the model to crash." msgstr "跳过在出口特征中发现的任何无效几何图形的划线。否则,一个无效的几何图形将导致模型崩溃。" #: src/natcap/invest/delineateit/delineateit.py:100 @@ -3769,16 +3197,13 @@ msgid "Either calc_n or calc_p must be True" msgstr "计算_n或计算_p必须为真" #: src/natcap/invest/ndr/ndr.py:48 -msgid "" -"All values in this raster must have corresponding entries in the " -"Biophysical table." +msgid "All values in this raster must have corresponding entries in the Biophysical table." msgstr "该光栅中的所有数值必须在生物物理表中有相应的条目。" #: src/natcap/invest/ndr/ndr.py:58 msgid "" -"Map of runoff potential, the capacity to transport nutrients downslope. " -"This can be a quickflow index or annual precipitation. Any units are " -"allowed since the values will be normalized by their average." +"Map of runoff potential, the capacity to transport nutrients downslope. This can be a quickflow index or annual precipitation. Any units are allowed since the values " +"will be normalized by their average." msgstr "径流潜力图,即向下坡输送营养物质的能力。这可以是一个快速流指数或年降水量。任何单位都是允许的,因为这些值将以其平均值为标准。" #: src/natcap/invest/ndr/ndr.py:63 @@ -3786,9 +3211,7 @@ msgid "nutrient runoff proxy" msgstr "营养物质径流代理" #: src/natcap/invest/ndr/ndr.py:70 -msgid "" -"Map of the boundaries of the watershed(s) over which to aggregate the " -"model results." +msgid "Map of the boundaries of the watershed(s) over which to aggregate the model results." msgstr "汇总模型结果的流域边界图。" #: src/natcap/invest/ndr/ndr.py:83 @@ -3796,38 +3219,29 @@ msgid "The nutrient loading for this land use class." msgstr "该土地使用类别的营养负荷。" #: src/natcap/invest/ndr/ndr.py:87 -msgid "" -"Maximum nutrient retention efficiency. This is the maximum proportion of " -"the nutrient that is retained on this LULC class." +msgid "Maximum nutrient retention efficiency. This is the maximum proportion of the nutrient that is retained on this LULC class." msgstr "最大养分保留效率。这是保留在该LULC等级上的最大养分比例。" #: src/natcap/invest/ndr/ndr.py:94 msgid "" -"The distance after which it is assumed that this LULC type retains the " -"nutrient at its maximum capacity. If nutrients travel a shorter distance " -"that this, the retention efficiency will be less than the maximum value " -"eff_x, following an exponential decay." +"The distance after which it is assumed that this LULC type retains the nutrient at its maximum capacity. If nutrients travel a shorter distance that this, the " +"retention efficiency will be less than the maximum value eff_x, following an exponential decay." msgstr "假设该LULC类型以其最大能力保留营养物的距离。如果营养物质的移动距离比这短,保留效率将小于最大值eff_x,呈指数衰减。" #: src/natcap/invest/ndr/ndr.py:104 msgid "" -"The proportion of the total amount of nitrogen that are dissolved into " -"the subsurface. By default, this value should be set to 0, indicating " -"that all nutrients are delivered via surface flow. There is no equivalent" -" of this for phosphorus." +"The proportion of the total amount of nitrogen that are dissolved into the subsurface. By default, this value should be set to 0, indicating that all nutrients are " +"delivered via surface flow. There is no equivalent of this for phosphorus." msgstr "溶解到地表下的氮总量的比例。默认情况下,这个值应该设置为0,表示所有的营养物质都通过地表流输送。对于磷,没有相应的数值。" #: src/natcap/invest/ndr/ndr.py:111 msgid "" -"A table mapping each LULC class to its biophysical properties related to " -"nutrient load and retention. Replace '[NUTRIENT]' in the column names " -"with 'n' or 'p' for nitrogen or phosphorus respectively. Nitrogen data " -"must be provided if Calculate Nitrogen is selected. Phosphorus data must " -"be provided if Calculate Phosphorus is selected. All LULC codes in the " -"LULC raster must have corresponding entries in this table." +"A table mapping each LULC class to its biophysical properties related to nutrient load and retention. Replace '[NUTRIENT]' in the column names with 'n' or 'p' for " +"nitrogen or phosphorus respectively. Nitrogen data must be provided if Calculate Nitrogen is selected. Phosphorus data must be provided if Calculate Phosphorus is " +"selected. All LULC codes in the LULC raster must have corresponding entries in this table." msgstr "" -"将每个LULC等级与其与养分负荷和保留有关的生物物理特性相匹配的表格。将列名中的\"[NUTRIENT]\"分别用 \"n \"或 \"p " -"\"代替氮或磷。如果选择计算氮,必须提供氮的数据。如果选择计算磷,则必须提供磷的数据。LULC栅格中的所有LULC代码必须在此表中有相应的条目。" +"将每个LULC等级与其与养分负荷和保留有关的生物物理特性相匹配的表格。将列名中的\"[NUTRIENT]\"分别用 \"n \"或 \"p \"代替氮或磷。如果选择计算氮,必须提供氮的数据。如果选择计" +"算磷,则必须提供磷的数据。LULC栅格中的所有LULC代码必须在此表中有相应的条目。" #: src/natcap/invest/ndr/ndr.py:124 msgid "Calculate phosphorus retention and export." @@ -3847,10 +3261,8 @@ msgstr "计算氮" #: src/natcap/invest/ndr/ndr.py:138 msgid "" -"Calibration parameter that determines the shape of the relationship " -"between hydrologic connectivity (the degree of connection from patches of" -" land to the stream) and the nutrient delivery ratio (percentage of " -"nutrient that actually reaches the stream)." +"Calibration parameter that determines the shape of the relationship between hydrologic connectivity (the degree of connection from patches of land to the stream) and " +"the nutrient delivery ratio (percentage of nutrient that actually reaches the stream)." msgstr "校准参数,决定了水文连通性(土地斑块与河流的连接程度)和营养物质输送率(实际到达河流的营养物质百分比)之间关系的形状。" #: src/natcap/invest/ndr/ndr.py:144 src/natcap/invest/sdr/sdr.py:112 @@ -3863,9 +3275,8 @@ msgstr "地下临界长度(氮气)" #: src/natcap/invest/ndr/ndr.py:151 msgid "" -"The distance traveled (subsurface and downslope) after which it is " -"assumed that soil retains nitrogen at its maximum capacity. Required if " -"Calculate Nitrogen is selected." +"The distance traveled (subsurface and downslope) after which it is assumed that soil retains nitrogen at its maximum capacity. Required if Calculate Nitrogen is " +"selected." msgstr "假设土壤以最大容量保留氮的距离(地表下和下坡)。如果选择 \"计算氮\",则需要。" #: src/natcap/invest/ndr/ndr.py:159 @@ -3874,9 +3285,8 @@ msgstr "地下最大保留效率(氮)。" #: src/natcap/invest/ndr/ndr.py:160 msgid "" -"The maximum nitrogen retention efficiency that can be reached through " -"subsurface flow. This characterizes the retention due to biochemical " -"degradation in soils. Required if Calculate Nitrogen is selected." +"The maximum nitrogen retention efficiency that can be reached through subsurface flow. This characterizes the retention due to biochemical degradation in soils. " +"Required if Calculate Nitrogen is selected." msgstr "通过地下流动可达到的最大氮保留效率。这表征了由于土壤中的生物化学降解而产生的滞留。如果选择计算氮,则需要。" #: src/natcap/invest/recreation/recmodel_client.py:51 @@ -3892,46 +3302,31 @@ msgid "The type of predictor file provided in the 'path' column." msgstr "路径栏中提供的预测器文件的类型。" #: src/natcap/invest/recreation/recmodel_client.py:66 -msgid "" -"Predictor is a raster. Metric is the mean of values within the AOI grid " -"cell or polygon." +msgid "Predictor is a raster. Metric is the mean of values within the AOI grid cell or polygon." msgstr "预测器是一个栅格。度量是AOI网格单元或多边形内数值的平均值。" #: src/natcap/invest/recreation/recmodel_client.py:70 -msgid "" -"Predictor is a raster. Metric is the sum of values within the AOI grid " -"cell or polygon." +msgid "Predictor is a raster. Metric is the sum of values within the AOI grid cell or polygon." msgstr "预测器是一个栅格。度量是AOI网格单元或多边形内的数值之和。" #: src/natcap/invest/recreation/recmodel_client.py:74 -msgid "" -"Predictor is a point vector. Metric is the number of points within each " -"AOI grid cell or polygon." +msgid "Predictor is a point vector. Metric is the number of points within each AOI grid cell or polygon." msgstr "预测器是一个点矢量。度量是每个AOI网格单元或多边形内的点的数量。" #: src/natcap/invest/recreation/recmodel_client.py:78 -#, fuzzy -msgid "" -"Predictor is a point vector. Metric is the Euclidean distance between the" -" centroid of each AOI grid cell and the nearest point in this layer." -msgstr "预测器是一个点矢量。度量是每个AOI网格单元的中心与本层最近的点之间的欧几里得距离。" +msgid "Predictor is a point vector. Metric is the Euclidean distance between the centroid of each AOI grid cell and the nearest point in this layer." +msgstr "预测器是一个点矢量。度量是每个AOI网格单元的质心与该图层中最近点之间的欧氏距离。" #: src/natcap/invest/recreation/recmodel_client.py:83 -msgid "" -"Predictor is a line vector. Metric is the total length of the lines that " -"fall within each AOI grid cell." +msgid "Predictor is a line vector. Metric is the total length of the lines that fall within each AOI grid cell." msgstr "预测器是一个线矢量。度量是属于每个AOI网格单元的线的总长度。" #: src/natcap/invest/recreation/recmodel_client.py:87 -msgid "" -"Predictor is a polygon vector. Metric is the area of overlap between the " -"polygon and each AOI grid cell." +msgid "Predictor is a polygon vector. Metric is the area of overlap between the polygon and each AOI grid cell." msgstr "预测器是一个多边形矢量。度量是多边形与每个AOI网格单元之间的重叠面积。" #: src/natcap/invest/recreation/recmodel_client.py:91 -msgid "" -"Predictor is a polygon vector. Metric is the percentage (0-100) of " -"overlapping area between the polygon and each AOI grid cell." +msgid "Predictor is a polygon vector. Metric is the percentage (0-100) of overlapping area between the polygon and each AOI grid cell." msgstr "预测器是一个多边形矢量。衡量标准是多边形与每个AOI网格单元之间的重叠面积百分比(0-100)。" #: src/natcap/invest/recreation/recmodel_client.py:110 @@ -3956,9 +3351,8 @@ msgstr "端口" #: src/natcap/invest/recreation/recmodel_client.py:134 msgid "" -"Year at which to start photo user-day calculations. Calculations start on" -" the first day of the year. Year must be in the range 2005 - 2017, and " -"must be less than or equal to the End Year." +"Year at which to start photo user-day calculations. Calculations start on the first day of the year. Year must be in the range 2005 - 2017, and must be less than or " +"equal to the End Year." msgstr "开始计算照片用户日的年份。计算从该年的第一天开始。年份必须在2005-2017范围内,并且必须小于或等于结束年份。" #: src/natcap/invest/recreation/recmodel_client.py:139 @@ -3967,9 +3361,8 @@ msgstr "起始年份" #: src/natcap/invest/recreation/recmodel_client.py:145 msgid "" -"Year at which to end photo user-day calculations. Calculations continue " -"through the last day of the year. Year must be in the range 2005 - 2017, " -"and must be greater than or equal to the Start Year." +"Year at which to end photo user-day calculations. Calculations continue through the last day of the year. Year must be in the range 2005 - 2017, and must be greater " +"than or equal to the Start Year." msgstr "结束照片用户日计算的年份。计算会持续到该年的最后一天。年份必须在2005-2017范围内,并且必须大于或等于起始年份。" #: src/natcap/invest/recreation/recmodel_client.py:150 @@ -3977,9 +3370,7 @@ msgid "end year" msgstr "结束年份" #: src/natcap/invest/recreation/recmodel_client.py:155 -msgid "" -"Divide the AOI polygons into equal-sized grid cells, and compute results " -"for those cells instead of the original polygons." +msgid "Divide the AOI polygons into equal-sized grid cells, and compute results for those cells instead of the original polygons." msgstr "将AOI的多边形划分为同等大小的网格单元,并对这些单元而非原始多边形进行计算。" #: src/natcap/invest/recreation/recmodel_client.py:159 @@ -3995,9 +3386,7 @@ msgid "hexagon" msgstr "六边形" #: src/natcap/invest/recreation/recmodel_client.py:168 -msgid "" -"The shape of grid cells to make within the AOI polygons. Required if Grid" -" AOI is selected." +msgid "The shape of grid cells to make within the AOI polygons. Required if Grid AOI is selected." msgstr "在AOI多边形范围内制作的网格单元的形状。如果选择了网格AOI,则需要。" #: src/natcap/invest/recreation/recmodel_client.py:171 @@ -4006,22 +3395,16 @@ msgstr "网格类型" #: src/natcap/invest/recreation/recmodel_client.py:178 msgid "" -"Size of grid cells to make, measured in the projection units of the AOI. " -"If the Grid Type is 'square', this is the length of each side of the " -"square. If the Grid Type is 'hexagon', this is the hexagon's maximal " -"diameter." -msgstr "" -"要制作的网格单元的尺寸,以AOI的投影单位衡量。如果网格类型是 \"正方形\",这就是正方形的每条边的长度。如果网格类型是 " -"\"六边形\",这是该六边形的最大直径。" +"Size of grid cells to make, measured in the projection units of the AOI. If the Grid Type is 'square', this is the length of each side of the square. If the Grid Type " +"is 'hexagon', this is the hexagon's maximal diameter." +msgstr "要制作的网格单元的尺寸,以AOI的投影单位衡量。如果网格类型是 \"正方形\",这就是正方形的每条边的长度。如果网格类型是 \"六边形\",这是该六边形的最大直径。" #: src/natcap/invest/recreation/recmodel_client.py:183 msgid "cell size" msgstr "单元大小" #: src/natcap/invest/recreation/recmodel_client.py:188 -msgid "" -"Run the regression model using the predictor table and scenario table, if" -" provided." +msgid "Run the regression model using the predictor table and scenario table, if provided." msgstr "使用预测表和情景表(如果提供)运行回归模型。" #: src/natcap/invest/recreation/recmodel_client.py:191 @@ -4029,9 +3412,7 @@ msgid "compute regression" msgstr "计算回归" #: src/natcap/invest/recreation/recmodel_client.py:198 -msgid "" -"A table that maps predictor IDs to spatial files and their predictor " -"metric types. The file paths can be absolute or relative to the table." +msgid "A table that maps predictor IDs to spatial files and their predictor metric types. The file paths can be absolute or relative to the table." msgstr "一个将预测器ID映射到空间文件及其预测器度量类型的表格。文件路径可以是绝对的,也可以是相对于该表的。" #: src/natcap/invest/recreation/recmodel_client.py:202 @@ -4039,9 +3420,7 @@ msgid "predictor table" msgstr "预测表" #: src/natcap/invest/recreation/recmodel_client.py:209 -msgid "" -"A table of future or alternative scenario predictors. Maps IDs to files " -"and their types. The file paths can be absolute or relative to the table." +msgid "A table of future or alternative scenario predictors. Maps IDs to files and their types. The file paths can be absolute or relative to the table." msgstr "一个未来或替代方案的预测表。将ID映射到文件和它们的类型。文件路径可以是绝对的,也可以是相对于该表的。" #: src/natcap/invest/recreation/recmodel_client.py:213 @@ -4050,89 +3429,84 @@ msgstr "情景预测表" #: src/natcap/invest/recreation/recmodel_client.py:218 msgid "Copy of the the AOI vector with aggregate attributes added." -msgstr "" +msgstr "带有聚合属性的AOI矢量的副本。" #: src/natcap/invest/recreation/recmodel_client.py:223 msgid "The average photo-user-days per year" -msgstr "" +msgstr "每年的平均照片用户天数" #: src/natcap/invest/recreation/recmodel_client.py:229 msgid "The average photo-user-days for each month." -msgstr "" +msgstr "每个月的平均照片用户天数。" #: src/natcap/invest/recreation/recmodel_client.py:237 msgid "Table of monthly photo-user-days." -msgstr "" +msgstr "每月照片用户天数表。" #: src/natcap/invest/recreation/recmodel_client.py:242 -#, fuzzy msgid "Polygon ID" -msgstr "陆地多边形" +msgstr "多边形 ID" #: src/natcap/invest/recreation/recmodel_client.py:245 msgid "Total photo-user-days counted in each cell in the given month." -msgstr "" +msgstr "在给定月份内每个单元格中计算的总照片用户天数。" #: src/natcap/invest/recreation/recmodel_client.py:255 msgid "AOI polygons with their corresponding predictor attributes." -msgstr "" +msgstr "带有相应预测器属性的AOI多边形。" -#: src/natcap/invest/recreation/recmodel_client.py:262 -#: src/natcap/invest/recreation/recmodel_client.py:287 +#: src/natcap/invest/recreation/recmodel_client.py:262 src/natcap/invest/recreation/recmodel_client.py:287 msgid "Predictor attribute value for each polygon." -msgstr "" +msgstr "每个多边形的预测器属性值。" #: src/natcap/invest/recreation/recmodel_client.py:269 msgid "" -"This is a text file output of the regression analysis. It includes " -"estimates for each predictor variable. It also contains a “server id " -"hash” value which can be used to correlate the PUD result with the data " -"available on the PUD server. If these results are used in publication " -"this hash should be included with the results for reproducibility." +"This is a text file output of the regression analysis. It includes estimates for each predictor variable. It also contains a “server id hash” value which can be used " +"to correlate the PUD result with the data available on the PUD server. If these results are used in publication this hash should be included with the results for " +"reproducibility." msgstr "" +"这是回归分析的文本文件输出。它包括每个预测变量的估计值。它还包含一个“服务器 ID 哈希”值,可以用来将 PUD 结果与 PUD 服务器上的数据相关联。如果这些结果用于出版,此哈希值应" +"与结果一起包含以进行可重现性。" #: src/natcap/invest/recreation/recmodel_client.py:279 -msgid "" -"AOI polygons with their corresponding predictor attributes in the " -"scenario." -msgstr "" +msgid "AOI polygons with their corresponding predictor attributes in the scenario." +msgstr "在该场景中,AOI多边形及其对应的预测属性。" #: src/natcap/invest/recreation/recmodel_client.py:293 msgid "The estimated PUD_YR_AVG per polygon." -msgstr "" +msgstr "每个多边形的估计PUD_YR_AVG。" #: src/natcap/invest/recreation/recmodel_client.py:301 msgid "Copy of the input AOI, gridded if applicable." -msgstr "" +msgstr "输入AOI的副本,如果适用的话,以网格化显示。" #: src/natcap/invest/recreation/recmodel_client.py:307 msgid "Compressed AOI" -msgstr "" +msgstr "压缩的AOI" #: src/natcap/invest/recreation/recmodel_client.py:310 msgid "aggregated predictor values within each polygon" -msgstr "" +msgstr "每个多边形内的汇总预测值" #: src/natcap/invest/recreation/recmodel_client.py:314 -#, fuzzy msgid "Predictor estimates" -msgstr "预测表" +msgstr "预测器估计值" #: src/natcap/invest/recreation/recmodel_client.py:317 msgid "Compressed photo-user-day data" -msgstr "" +msgstr "压缩的照片用户日数据" #: src/natcap/invest/recreation/recmodel_client.py:319 msgid "Pickled dictionary mapping FIDs to shapely geometries" -msgstr "" +msgstr "将FIDs映射到Shapely几何图形的Pickled字典" #: src/natcap/invest/recreation/recmodel_client.py:326 msgid "aggregated scenario predictor values within each polygon" -msgstr "" +msgstr "每个多边形内的汇总情景预测值" #: src/natcap/invest/recreation/recmodel_client.py:333 msgid "Server version info" -msgstr "" +msgstr "服务器版本信息" #: src/natcap/invest/scenic_quality/scenic_quality.py:66 msgid "features impacting scenic quality" @@ -4140,31 +3514,25 @@ msgstr "影响风景质量的特征" #: src/natcap/invest/scenic_quality/scenic_quality.py:74 msgid "" -"Maximum length of the line of sight originating from a viewpoint. The " -"value can either be positive (preferred) or negative (kept for backwards " -"compatibility), but is converted to a positive number. If this field is " -"not provided, the model will include all pixels in the DEM in the " -"visibility analysis. RADIUS preferred, but may also be called RADIUS2 for" -" backwards compatibility." -msgstr "源自一个观点的视线的最大长度。该值可以是正数(首选)或负数(为向后兼容而保留),但要转换为正数。如果不提供这个字段,模型将在可见度分析中包括DEM中的所有像素。首选RADIUS,但也可以称为RADIUS2,以便向后兼容。" +"Maximum length of the line of sight originating from a viewpoint. The value can either be positive (preferred) or negative (kept for backwards compatibility), but is " +"converted to a positive number. If this field is not provided, the model will include all pixels in the DEM in the visibility analysis. RADIUS preferred, but may also " +"be called RADIUS2 for backwards compatibility." +msgstr "" +"源自一个观点的视线的最大长度。该值可以是正数(首选)或负数(为向后兼容而保留),但要转换为正数。如果不提供这个字段,模型将在可见度分析中包括DEM中的所有像素。首选" +"RADIUS,但也可以称为RADIUS2,以便向后兼容。" #: src/natcap/invest/scenic_quality/scenic_quality.py:87 msgid "" -"Viewshed importance coefficient. If this field is provided, the values " -"are used to weight each feature's viewshed impacts. If not provided, all " -"viewsheds are equally weighted with a weight of 1." +"Viewshed importance coefficient. If this field is provided, the values are used to weight each feature's viewshed impacts. If not provided, all viewsheds are equally " +"weighted with a weight of 1." msgstr "景观重要性系数。如果提供了这个字段,其值将用于加权每个特征的视域影响。如果没有提供,则所有视域的权重相同,权重为1。" #: src/natcap/invest/scenic_quality/scenic_quality.py:96 -msgid "" -"Viewpoint height, the elevation above the ground of each feature. If this" -" field is not provided, defaults to 0." +msgid "Viewpoint height, the elevation above the ground of each feature. If this field is not provided, defaults to 0." msgstr "视点高度,每个特征在地面上的高度。如果没有提供这个字段,默认为0。" #: src/natcap/invest/scenic_quality/scenic_quality.py:101 -msgid "" -"Map of locations of objects that negatively affect scenic quality. This " -"must have the same projection as the DEM." +msgid "Map of locations of objects that negatively affect scenic quality. This must have the same projection as the DEM." msgstr "对景区质量有负面影响的物体的位置图。这必须具有与DEM相同的投影。" #: src/natcap/invest/scenic_quality/scenic_quality.py:111 @@ -4172,9 +3540,7 @@ msgid "refractivity coefficient" msgstr "折射系数" #: src/natcap/invest/scenic_quality/scenic_quality.py:113 -msgid "" -"The refractivity coefficient corrects for the curvature of the earth and " -"refraction of visible light in air." +msgid "The refractivity coefficient corrects for the curvature of the earth and refraction of visible light in air." msgstr "折射率系数修正了地球的曲率和可见光在空气中的折射。" #: src/natcap/invest/scenic_quality/scenic_quality.py:124 @@ -4194,9 +3560,7 @@ msgid "exponential: a * e^(-bx)" msgstr "指数:a * e^(-bx)" #: src/natcap/invest/scenic_quality/scenic_quality.py:133 -msgid "" -"Valuation function used to calculate the visual impact of each feature, " -"given distance from the feature 'x' and parameters 'a' and 'b'." +msgid "Valuation function used to calculate the visual impact of each feature, given distance from the feature 'x' and parameters 'a' and 'b'." msgstr "用于计算每个特征的视觉影响的评价函数,给定与特征'x'的距离和参数'a'和'b'。" #: src/natcap/invest/scenic_quality/scenic_quality.py:139 @@ -4220,71 +3584,51 @@ msgid "maximum valuation radius" msgstr "最大估价半径" #: src/natcap/invest/scenic_quality/scenic_quality.py:158 -msgid "" -"Valuation will only be computed for cells that fall within this radius of" -" a feature impacting scenic quality." +msgid "Valuation will only be computed for cells that fall within this radius of a feature impacting scenic quality." msgstr "只有在影响风景质量的特征的这个半径范围内的单元才会被计算出估值。" #: src/natcap/invest/scenic_quality/scenic_quality.py:168 msgid "Map of visual quality classified into quartiles." -msgstr "" +msgstr "分为四分位数的视觉质量地图。" #: src/natcap/invest/scenic_quality/scenic_quality.py:173 msgid "" -"This raster layer contains the weighted sum of all visibility rasters. If" -" no weight column is provided in the structures point vector, this raster" -" will represent a count of the number of structure points that are " -"visible from each pixel." -msgstr "" +"This raster layer contains the weighted sum of all visibility rasters. If no weight column is provided in the structures point vector, this raster will represent a " +"count of the number of structure points that are visible from each pixel." +msgstr "此栅格图层包含所有可见性栅格的加权总和。如果结构点矢量中未提供权重列,则此栅格将表示每个像素中可见的结构点的数量。" #: src/natcap/invest/scenic_quality/scenic_quality.py:177 -msgid "" -"This raster layer contains the weighted sum of the valuation rasters " -"created for each point." -msgstr "" +msgid "This raster layer contains the weighted sum of the valuation rasters created for each point." +msgstr "此栅格图层包含为每个点创建的赋值栅格的加权和。" #: src/natcap/invest/scenic_quality/scenic_quality.py:186 -msgid "" -"This vector is the AOI, reprojected to the DEM’s spatial reference and " -"projection." -msgstr "" +msgid "This vector is the AOI, reprojected to the DEM’s spatial reference and projection." +msgstr "该矢量是AOI,重新投影到DEM的空间参考和投影中。" #: src/natcap/invest/scenic_quality/scenic_quality.py:191 -msgid "" -"This raster layer is a version of the DEM that has been clipped and " -"masked to the AOI and tiled. This is the DEM file that is used for the " -"viewshed analysis." -msgstr "" +msgid "This raster layer is a version of the DEM that has been clipped and masked to the AOI and tiled. This is the DEM file that is used for the viewshed analysis." +msgstr "此栅格图层是已被裁剪和遮罩至AOI并进行切片的DEM版本。这是用于视域分析的DEM文件。" #: src/natcap/invest/scenic_quality/scenic_quality.py:195 msgid "Copy of the structures vector, clipped to the AOI extent." -msgstr "" +msgstr "剪切到AOI范围的结构矢量的副本。" #: src/natcap/invest/scenic_quality/scenic_quality.py:201 -msgid "" -"Copy of the structures vector, reprojected to the DEM’s spatial reference" -" and projection." -msgstr "" +msgid "Copy of the structures vector, reprojected to the DEM’s spatial reference and projection." +msgstr "结构矢量的副本,重新投影到DEM的空间参考和投影中。" #: src/natcap/invest/scenic_quality/scenic_quality.py:206 msgid "" -"The calculated value of the viewshed amenity/disamenity given the " -"distances of pixels from the structure's viewpoint, the weight of the " -"viewpoint, the valuation function, and the a and b coefficients. The " -"viewshed’s value is only evaluated for visible pixels." -msgstr "" +"The calculated value of the viewshed amenity/disamenity given the distances of pixels from the structure's viewpoint, the weight of the viewpoint, the valuation " +"function, and the a and b coefficients. The viewshed’s value is only evaluated for visible pixels." +msgstr "在给定结构视点的像素距离、视点权重、估值函数以及a和b系数的情况下,视域舒适度/舒适度的计算值。视域的值仅针对可见像素进行评估。" #: src/natcap/invest/scenic_quality/scenic_quality.py:210 -msgid "" -"Map of visibility for a given structure's viewpoint. This raster has " -"pixel values of 0 (not visible), 1 (visible), or nodata (where the DEM is" -" nodata)." -msgstr "" +msgid "Map of visibility for a given structure's viewpoint. This raster has pixel values of 0 (not visible), 1 (visible), or nodata (where the DEM is nodata)." +msgstr "给定结构视点的可见性地图。此栅格的像素值为0(不可见)、1(可见)或nodata(其中DEM为nodata)。" #: src/natcap/invest/sdr/sdr.py:54 -msgid "" -"Map of rainfall erosivity, reflecting the intensity and duration of " -"rainfall in the area of interest." +msgid "Map of rainfall erosivity, reflecting the intensity and duration of rainfall in the area of interest." msgstr "降雨侵蚀性地图,反映了有关地区的降雨强度和时间。" #: src/natcap/invest/sdr/sdr.py:57 @@ -4292,9 +3636,7 @@ msgid "erosivity" msgstr "侵蚀性" #: src/natcap/invest/sdr/sdr.py:65 -msgid "" -"Map of soil erodibility, the susceptibility of soil particles to " -"detachment and transport by rainfall and runoff." +msgid "Map of soil erodibility, the susceptibility of soil particles to detachment and transport by rainfall and runoff." msgstr "土壤侵蚀性地图,土壤颗粒容易被降雨和径流剥离和运输。" #: src/natcap/invest/sdr/sdr.py:69 @@ -4303,9 +3645,7 @@ msgstr "土壤侵蚀性" #: src/natcap/invest/sdr/sdr.py:83 msgid "" -"Map of the boundaries of the watershed(s) over which to aggregate " -"results. Each watershed should contribute to a point of interest where " -"water quality will be analyzed." +"Map of the boundaries of the watershed(s) over which to aggregate results. Each watershed should contribute to a point of interest where water quality will be analyzed." msgstr "汇总结果的流域边界图。每一个流域都应该为一个兴趣点做出贡献,在那里将对水质进行分析。" #: src/natcap/invest/sdr/sdr.py:87 @@ -4321,10 +3661,7 @@ msgid "Support practice factor for the USLE" msgstr "支持USLE的实践因素" #: src/natcap/invest/sdr/sdr.py:101 -msgid "" -"A table mapping each LULC code to biophysical properties of that LULC " -"class. All values in the LULC raster must have corresponding entries in " -"this table." +msgid "A table mapping each LULC code to biophysical properties of that LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "一个将每个LULC代码与该LULC类别的生物物理属性相匹配的表格。LULC栅格中的所有数值必须在此表中有相应的条目。" #: src/natcap/invest/sdr/sdr.py:111 @@ -4348,9 +3685,7 @@ msgid "Borselli IC0 parameter" msgstr "Borselli IC0参数" #: src/natcap/invest/sdr/sdr.py:129 -msgid "" -"The maximum allowed value of the slope length parameter (L) in the LS " -"factor." +msgid "The maximum allowed value of the slope length parameter (L) in the LS factor." msgstr "LS因子中斜率长度参数(L)的最大允许值。" #: src/natcap/invest/sdr/sdr.py:132 @@ -4358,10 +3693,7 @@ msgid "maximum l value" msgstr "最大l值" #: src/natcap/invest/sdr/sdr.py:138 -msgid "" -"Map of locations of artificial drainages that drain to the watershed. " -"Pixels with 1 are drainages and are treated like streams. Pixels with 0 " -"are not drainages." +msgid "Map of locations of artificial drainages that drain to the watershed. Pixels with 1 are drainages and are treated like streams. Pixels with 0 are not drainages." msgstr "流入流域的人工排水沟位置图。带1的像素是排水沟,与溪流一样处理。带0的像素不是排水沟。" #: src/natcap/invest/sdr/sdr.py:142 @@ -4369,172 +3701,133 @@ msgid "drainages" msgstr "排水渠" #: src/natcap/invest/sdr/sdr.py:229 -#, fuzzy -msgid "" -"CP factor derived by mapping usle_c and usle_p from the biophysical table" -" to the LULC raster." -msgstr "将每个LULC代码从LULC映射到该LULC类的生物物理数据的表。" +msgid "CP factor derived by mapping usle_c and usle_p from the biophysical table to the LULC raster." +msgstr "通过将生物物理表中的usle_c和usle_p映射到LULC栅格得出的CP因子。" #: src/natcap/invest/sdr/sdr.py:235 msgid "Downslope factor of the index of connectivity (Eq. (74))" -msgstr "" +msgstr "连通性指数的下坡系数(公式.(74))" #: src/natcap/invest/sdr/sdr.py:240 msgid "Upslope factor of the index of connectivity (Eq. (73))" -msgstr "" +msgstr "连通性指数的上坡系数(公式.(73))" #: src/natcap/invest/sdr/sdr.py:245 -msgid "" -"Sediment downslope deposition, the amount of sediment from a given pixel " -"that does not reach a stream (Eq. (78))" -msgstr "" +msgid "Sediment downslope deposition, the amount of sediment from a given pixel that does not reach a stream (Eq. (78))" +msgstr "沉积物下坡沉积,给定像素中未到达河流的沉积物量(公式.(78))" #: src/natcap/invest/sdr/sdr.py:254 -msgid "" -"Map of sediment flux for sediment that does not reach the stream (Eq. " -"(81))" -msgstr "" +msgid "Map of sediment flux for sediment that does not reach the stream (Eq. (81))" +msgstr "未到达河流的沉积物的沉积物通量图(公式.(81))" #: src/natcap/invest/sdr/sdr.py:265 msgid "Index of connectivity (Eq. (70))" -msgstr "" +msgstr "连通性指数(公式.(70))" #: src/natcap/invest/sdr/sdr.py:272 msgid "LS factor for USLE (Eq. (69))" -msgstr "" +msgstr "USLE的LS因子(公式.(69))" #: src/natcap/invest/sdr/sdr.py:280 -msgid "" -"Flow accumulation weighted by the thresholded slope. Used in calculating " -"s_bar." -msgstr "" +msgid "Flow accumulation weighted by the thresholded slope. Used in calculating s_bar." +msgstr "阈值斜率加权的流量累积。用于计算s_bar。" #: src/natcap/invest/sdr/sdr.py:289 -msgid "" -"Mean thresholded slope gradient of the upslope contributing area (in eq. " -"(73))" -msgstr "" +msgid "Mean thresholded slope gradient of the upslope contributing area (in eq. (73))" +msgstr "上坡贡献区的平均阈值坡度(公式.(73))" #: src/natcap/invest/sdr/sdr.py:298 -#, fuzzy msgid "Sediment delivery ratio (Eq. (75))" -msgstr "泥沙输移比" +msgstr "泥沙输送比(公式.(75))" #: src/natcap/invest/sdr/sdr.py:303 -msgid "" -"Percent slope, thresholded to be no less than 0.005 and no greater than 1" -" (eq. (71)). 1 is equivalent to a 45 degree slope." -msgstr "" +msgid "Percent slope, thresholded to be no less than 0.005 and no greater than 1 (eq. (71)). 1 is equivalent to a 45 degree slope." +msgstr "百分比斜率,阈值不小于0.005且不大于1(公式.(71)).1相当于45度的坡度。" #: src/natcap/invest/sdr/sdr.py:310 -msgid "" -"Flow accumulation weighted by the thresholded cover-management factor. " -"Used in calculating w_bar." -msgstr "" +msgid "Flow accumulation weighted by the thresholded cover-management factor. Used in calculating w_bar." +msgstr "阈值覆盖管理因子加权的流量累积。用于计算w_bar。" #: src/natcap/invest/sdr/sdr.py:319 -msgid "" -"Mean thresholded cover-management factor for upslope contributing area " -"(in eq. (73))" -msgstr "" +msgid "Mean thresholded cover-management factor for upslope contributing area (in eq. (73))" +msgstr "上坡影响区的平均阈值覆盖管理系数(公式.(73))" #: src/natcap/invest/sdr/sdr.py:325 -msgid "" -"Cover-management factor derived by mapping usle_c from the biophysical " -"table to the LULC raster." -msgstr "" +msgid "Cover-management factor derived by mapping usle_c from the biophysical table to the LULC raster." +msgstr "通过将usle_c从生物物理表映射到LULC栅格得出的覆盖管理系数。" #: src/natcap/invest/sdr/sdr.py:331 msgid "Cover-management factor thresholded to be no less than 0.001 (eq. (72))" -msgstr "" +msgstr "覆盖管理因子阈值不小于0.001(公式.(72))" #: src/natcap/invest/sdr/sdr.py:337 msgid "Average aspect weighted by flow direction (in eq. (69))" -msgstr "" +msgstr "按流向加权的平均坡向(公式.(69))" #: src/natcap/invest/sdr/sdr.py:342 msgid "" -"Map of which pixels drain to a stream. A value of 1 means that at least " -"some of the runoff from that pixel drains to a stream in stream.tif. A " -"value of 0 means that it does not drain at all to any stream in " -"stream.tif." -msgstr "" +"Map of which pixels drain to a stream. A value of 1 means that at least some of the runoff from that pixel drains to a stream in stream.tif. A value of 0 means that it " +"does not drain at all to any stream in stream.tif." +msgstr "哪些像素流向河流的映射。值为1表示该像素的径流至少有一部分排入stream.tif中的河流。值为0表示它根本不会排入stream.tif中的任何河流。" #: src/natcap/invest/sdr/sdr.py:351 -msgid "" -"Inverse of the thresholded cover-management factor times the thresholded " -"slope (in eq. (74))" -msgstr "" +msgid "Inverse of the thresholded cover-management factor times the thresholded slope (in eq. (74))" +msgstr "阈值化覆盖管理因子乘以阈值化斜率的倒数(公式.(74))" #: src/natcap/invest/sdr/sdr.py:357 msgid "Copy of the input DEM, clipped to the extent of the other raster inputs." -msgstr "" +msgstr "输入DEM的副本,裁剪至其他栅格输入的范围。" #: src/natcap/invest/sdr/sdr.py:366 -msgid "" -"Copy of the input drainage map, clipped to the extent of the other raster" -" inputs and aligned to the DEM." -msgstr "" +msgid "Copy of the input drainage map, clipped to the extent of the other raster inputs and aligned to the DEM." +msgstr "输入流域地图的副本,裁剪到其他栅格输入的范围并与DEM对齐。" #: src/natcap/invest/sdr/sdr.py:373 -msgid "" -"Copy of the input erodibility map, clipped to the extent of the other " -"raster inputs and aligned to the DEM." -msgstr "" +msgid "Copy of the input erodibility map, clipped to the extent of the other raster inputs and aligned to the DEM." +msgstr "输入可侵蚀性地图的副本,裁剪至其他栅格输入的范围并与DEM对齐。" #: src/natcap/invest/sdr/sdr.py:383 -msgid "" -"Copy of the input erosivity map, clipped to the extent of the other " -"raster inputs and aligned to the DEM." -msgstr "" +msgid "Copy of the input erosivity map, clipped to the extent of the other raster inputs and aligned to the DEM." +msgstr "输入侵蚀力地图的副本,裁剪至其他栅格输入的范围并与DEM对齐。" #: src/natcap/invest/sdr/sdr.py:393 -msgid "" -"Copy of the input Land Use Land Cover map, clipped to the extent of the " -"other raster inputs and aligned to the DEM." -msgstr "" +msgid "Copy of the input Land Use Land Cover map, clipped to the extent of the other raster inputs and aligned to the DEM." +msgstr "输入土地利用土地覆盖图的副本,裁剪至其他栅格输入的范围并与DEM对齐。" #: src/natcap/invest/sdr/sdr.py:400 msgid "" -"A raster aligned to the DEM and clipped to the extent of the other raster" -" inputs. Pixel values indicate where a nodata value exists in the stack " -"of aligned rasters (pixel value of 0), or if all values in the stack of " -"rasters at this pixel location are valid." -msgstr "" +"A raster aligned to the DEM and clipped to the extent of the other raster inputs. Pixel values indicate where a nodata value exists in the stack of aligned rasters " +"(pixel value of 0), or if all values in the stack of rasters at this pixel location are valid." +msgstr "与DEM对齐并裁剪到其他栅格输入范围的栅格。像素值表示对齐栅格堆栈中nodata值的位置(像素值为0),或者栅格堆栈中位于此像素位置的所有值是否都有效。" #: src/natcap/invest/sdr/sdr.py:410 msgid "A copy of the aligned DEM, masked using the mask raster." -msgstr "" +msgstr "使用掩膜栅格进行掩膜的对齐DEM的副本。" #: src/natcap/invest/sdr/sdr.py:418 msgid "A copy of the aligned drainage map, masked using the mask raster." -msgstr "" +msgstr "使用掩膜栅格进行掩膜的对齐水系图的副本。" #: src/natcap/invest/sdr/sdr.py:425 msgid "A copy of the aligned erodibility map, masked using the mask raster." -msgstr "" +msgstr "使用掩膜栅格进行掩膜的对齐的可侵蚀性地图的副本。" #: src/natcap/invest/sdr/sdr.py:435 msgid "A copy of the aligned erosivity map, masked using the mask raster." -msgstr "" +msgstr "使用掩膜栅格进行掩膜的对齐侵蚀性地图的副本。" #: src/natcap/invest/sdr/sdr.py:444 -msgid "" -"A copy of the aligned Land Use Land Cover map, masked using the mask " -"raster." -msgstr "" +msgid "A copy of the aligned Land Use Land Cover map, masked using the mask raster." +msgstr "使用掩膜栅格进行掩膜的对齐土地利用土地覆盖图的副本。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:53 msgid "" -"Twelve files, one for each month. File names must end with the month " -"number (1-12). For example, the filenames 'et0_1.tif' " -"'evapotranspiration1.tif' are both valid for the month of January." +"Twelve files, one for each month. File names must end with the month number (1-12). For example, the filenames 'et0_1.tif' 'evapotranspiration1.tif' are both valid for " +"the month of January." msgstr "12个文件,每个月一个。文件名必须以月份编号(1-12)结尾。例如,文件名'et0_1.tif''evapotranspiration1.tif'都对1月份有效。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:62 -msgid "" -"Directory containing maps of reference evapotranspiration for each month." -" Only .tif files should be in this folder (no .tfw, .xml, etc files)." +msgid "Directory containing maps of reference evapotranspiration for each month. Only .tif files should be in this folder (no .tfw, .xml, etc files)." msgstr "包含每个月的参考蒸发量地图的目录。在这个文件夹中只有.tif文件(没有.tfw、.xml等文件)。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:66 @@ -4543,15 +3836,12 @@ msgstr "模型数据目录" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:74 msgid "" -"Twelve files, one for each month. File names must end with the month " -"number (1-12). For example, the filenames 'precip_1.tif' and " -"'precip1.tif' are both valid names for the month of January." +"Twelve files, one for each month. File names must end with the month number (1-12). For example, the filenames 'precip_1.tif' and 'precip1.tif' are both valid names " +"for the month of January." msgstr "12个文件,每个月一个。文件名必须以月号(1-12)结尾。例如,文件名'precip_1.tif'和'precip1.tif'都是一月的有效名称。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:82 -msgid "" -"Directory containing maps of monthly precipitation for each month. Only " -".tif files should be in this folder (no .tfw, .xml, etc files)." +msgid "Directory containing maps of monthly precipitation for each month. Only .tif files should be in this folder (no .tfw, .xml, etc files)." msgstr "包含每个月的月度降水量地图的目录。在这个文件夹中只能有.tif文件(没有.tfw、.xml等文件)。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:86 @@ -4559,37 +3849,26 @@ msgid "precipitation directory" msgstr "降水目录" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:95 -msgid "" -"All values in this raster MUST have corresponding entries in the " -"Biophysical Table." +msgid "All values in this raster MUST have corresponding entries in the Biophysical Table." msgstr "该栅格中的所有数值必须在生物物理表中有相应的条目。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:116 msgid "" -"Curve number values for each combination of soil group and LULC class. " -"Replace [SOIL_GROUP] with each soil group code A, B, C, D so that there " -"is one column for each soil group. Curve number values must be greater " -"than 0." +"Curve number values for each combination of soil group and LULC class. Replace [SOIL_GROUP] with each soil group code A, B, C, D so that there is one column for each " +"soil group. Curve number values must be greater than 0." msgstr "土壤组和LULC等级的每个组合的曲线数值。用每个土壤组的代码A、B、C、D替换[SOIL_GROUP],这样每个土壤组就有一列。曲线编号值必须大于0。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:126 -msgid "" -"Crop/vegetation coefficient (Kc) values for this LULC class in each " -"month. Replace [MONTH] with the numbers 1 to 12 so that there is one " -"column for each month." +msgid "Crop/vegetation coefficient (Kc) values for this LULC class in each month. Replace [MONTH] with the numbers 1 to 12 so that there is one column for each month." msgstr "该LULC等级在每个月的作物/植被系数(Kc)值。用数字1至12代替[MONTH],这样每个月就有一列。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:133 msgid "" -"A table mapping each LULC code to biophysical properties of the " -"corresponding LULC class. All values in the LULC raster must have " -"corresponding entries in this table." +"A table mapping each LULC code to biophysical properties of the corresponding LULC class. All values in the LULC raster must have corresponding entries in this table." msgstr "将每个LULC代码与相应的LULC类别的生物物理属性进行映射的表格。LULC栅格中的所有数值必须在此表中有相应的条目。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:146 -msgid "" -"Values are the numbers 1-12 corresponding to each month, January (1) " -"through December (12)." +msgid "Values are the numbers 1-12 corresponding to each month, January (1) through December (12)." msgstr "数值为1-12的数字,对应每个月,1月(1)到12月(12)。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:153 @@ -4597,10 +3876,7 @@ msgid "The number of rain events in that month." msgstr "该月的雨水事件的数量。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:159 -msgid "" -"A table containing the number of rain events for each month. Required if " -"neither User-Defined Local Recharge nor User-Defined Climate Zones is " -"selected." +msgid "A table containing the number of rain events for each month. Required if neither User-Defined Local Recharge nor User-Defined Climate Zones is selected." msgstr "一个包含每个月雨量事件数量的表格。如果既没有选择用户定义的本地补给,也没有选择用户定义的气候区,则需要。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:163 @@ -4608,10 +3884,7 @@ msgid "rain events table" msgstr "降雨事件表" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:168 -msgid "" -"The proportion of upslope annual available local recharge that is " -"available in each month. Required if Use Monthly Alpha Table is not " -"selected." +msgid "The proportion of upslope annual available local recharge that is available in each month. Required if Use Monthly Alpha Table is not selected." msgstr "每个月的上坡年可用本地补给量的比例。如果不选择使用月度阿尔法表,则需要。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:172 @@ -4619,9 +3892,7 @@ msgid "alpha_m parameter" msgstr "alpha_m 参数" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:176 -msgid "" -"The proportion of the upgradient subsidy that is available for " -"downgradient evapotranspiration." +msgid "The proportion of the upgradient subsidy that is available for downgradient evapotranspiration." msgstr "可用于下流蒸发的上流补给的比例。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:179 @@ -4629,9 +3900,7 @@ msgid "beta_i parameter" msgstr "beta_i 参数" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:183 -msgid "" -"The proportion of pixel local recharge that is available to downgradient " -"pixels." +msgid "The proportion of pixel local recharge that is available to downgradient pixels." msgstr "下游栅格可获得的栅格本地补给比例。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:186 @@ -4639,9 +3908,7 @@ msgid "gamma parameter" msgstr "gamma参数" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:190 -msgid "" -"Use user-defined local recharge data instead of calculating local " -"recharge from the other provided data." +msgid "Use user-defined local recharge data instead of calculating local recharge from the other provided data." msgstr "使用用户定义的本地补给数据,而不是根据其他提供的数据计算本地补给。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:193 @@ -4649,9 +3916,7 @@ msgid "user-defined recharge layer (advanced)" msgstr "用户定义的补给层(高级)" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:203 -msgid "" -"Map of local recharge data. Required if User-Defined Local Recharge is " -"selected." +msgid "Map of local recharge data. Required if User-Defined Local Recharge is selected." msgstr "本地补给数据的地图。如果选择用户定义的本地补给,则需要。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:206 @@ -4667,25 +3932,17 @@ msgid "climate zones (advanced)" msgstr "气候区(高级)" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:221 -msgid "" -"Climate zone ID numbers, corresponding to the values in the Climate Zones" -" map." +msgid "Climate zone ID numbers, corresponding to the values in the Climate Zones map." msgstr "气候区ID号,与气候区地图中的数值相对应。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:227 msgid "" -"The number of rain events that occur in each month in this climate zone. " -"Replace [MONTH] with the month abbreviations: jan, feb, mar, apr, may, " -"jun, jul, aug, sep, oct, nov, dec, so that there is a column for each " -"month." -msgstr "" -"该气候区每月发生的雨量事件的数量。将[MONTH]改为月份缩写:Jan, feb, mar, apr, may, jun, jul, aug, " -"sep, oct, nov, dec,这样,每个月都有一列。" +"The number of rain events that occur in each month in this climate zone. Replace [MONTH] with the month abbreviations: jan, feb, mar, apr, may, jun, jul, aug, sep, " +"oct, nov, dec, so that there is a column for each month." +msgstr "该气候区每月发生的雨量事件的数量。将[MONTH]改为月份缩写:Jan, feb, mar, apr, may, jun, jul, aug, sep, oct, nov, dec,这样,每个月都有一列。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:235 -msgid "" -"Table of monthly precipitation events for each climate zone. Required if " -"User-Defined Climate Zones is selected." +msgid "Table of monthly precipitation events for each climate zone. Required if User-Defined Climate Zones is selected." msgstr "每个气候区的月降水事件表。如果选择了“自定义气候区”,则需要。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:238 @@ -4693,9 +3950,7 @@ msgid "climate zone table" msgstr "气候区表" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:245 -msgid "" -"Map of climate zones. All values in this raster must have corresponding " -"entries in the Climate Zone Table." +msgid "Map of climate zones. All values in this raster must have corresponding entries in the Climate Zone Table." msgstr "气候区地图。该栅格中的所有值必须在气候区表中有相应的条目。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:248 @@ -4719,9 +3974,7 @@ msgid "The alpha value for that month." msgstr "该月的alpha值。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:275 -msgid "" -"Table of alpha values for each month. Required if Use Monthly Alpha Table" -" is selected." +msgid "Table of alpha values for each month. Required if Use Monthly Alpha Table is selected." msgstr "每个月的alpha值表。如果选中“使用月Alpha表”,则需要。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:278 @@ -4729,160 +3982,124 @@ msgid "monthly alpha table" msgstr "月alpha表" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:283 -msgid "" -"Map of baseflow values, the contribution of a pixel to slow release flow " -"(which is not evapotranspired before it reaches the stream)." -msgstr "" +msgid "Map of baseflow values, the contribution of a pixel to slow release flow (which is not evapotranspired before it reaches the stream)." +msgstr "基本流量值的映射,像素对缓慢释放流量的贡献(在到达河流之前不会蒸发)。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:293 -msgid "" -"Map of B_sum values, the flow through a pixel, contributed by all upslope" -" pixels, that is not evapotranspirated before it reaches the stream." -msgstr "" +msgid "Map of B_sum values, the flow through a pixel, contributed by all upslope pixels, that is not evapotranspirated before it reaches the stream." +msgstr "B_sum值的映射,通过像素的流量,由所有上坡像素贡献,在到达河流之前不会蒸发。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:303 -#, fuzzy msgid "Map of curve number values." -msgstr "道路中心线地图" +msgstr "曲线数值图。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:310 -#, fuzzy msgid "Map of available local recharge" -msgstr "本地补给" +msgstr "可用本地补给地图" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:317 -#, fuzzy msgid "Map of local recharge values" -msgstr "本地补给" +msgstr "本地充值值地图" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:324 -msgid "" -"Map of total available water, contributed by all upslope pixels, that is " -"available for evapotranspiration by this pixel." -msgstr "" +msgid "Map of total available water, contributed by all upslope pixels, that is available for evapotranspiration by this pixel." +msgstr "由所有上坡像素贡献的总可用水量地图,可用于此像素的蒸散。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:333 -msgid "" -"Map of cumulative upstream recharge: the flow through a pixel, " -"contributed by all upslope pixels, that is available for " -"evapotranspiration to downslope pixels." -msgstr "" +msgid "Map of cumulative upstream recharge: the flow through a pixel, contributed by all upslope pixels, that is available for evapotranspiration to downslope pixels." +msgstr "累积上游补给图:通过像素的流量,由所有上坡像素贡献,可用于向下坡像素的蒸散。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:343 msgid "Map of quickflow" -msgstr "" +msgstr "快速流图" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:350 msgid "The total precipitation across all months on this pixel." -msgstr "" +msgstr "此像素上所有月份的总降水量。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:357 -msgid "" -"Map of the values of recharge (contribution, positive or negative), to " -"the total recharge." -msgstr "" +msgid "Map of the values of recharge (contribution, positive or negative), to the total recharge." +msgstr "充值值(贡献,正或负)与总充值的关系图。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:366 -#, fuzzy msgid "Table of biophysical values for each watershed" -msgstr "每个LULC类别的生物物理特性表。" +msgstr "每个流域的生物物理值表" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:370 msgid "Mean local recharge value within the watershed" -msgstr "" +msgstr "流域内的平均局部补给值" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:376 msgid "Total recharge contribution, (positive or negative) within the watershed." -msgstr "" +msgstr "流域内的总补给贡献(正或负)。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:388 -#, fuzzy msgid "Map of actual evapotranspiration" -msgstr "蒸发量值地图。" +msgstr "实际蒸散量图" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:395 -msgid "" -"Map of multiple flow direction. Values are encoded in a binary format and" -" should not be used directly." -msgstr "" +msgid "Map of multiple flow direction. Values are encoded in a binary format and should not be used directly." +msgstr "多流向地图。值以二进制格式编码,不应直接使用。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:401 msgid "Maps of monthly quickflow (1 = January… 12 = December)" -msgstr "" +msgstr "每月quickflow地图(1 = 1月…12 = 12月)" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:409 -msgid "" -"Stream network map generated from the input DEM and Threshold Flow " -"Accumulation. Values of 1 represent streams, values of 0 are non-stream " -"pixels." -msgstr "" +msgid "Stream network map generated from the input DEM and Threshold Flow Accumulation. Values of 1 represent streams, values of 0 are non-stream pixels." +msgstr "根据输入DEM和阈值流量累积生成的河流网络图。值1表示流,值0表示非流像素。" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:418 msgid "Map of the S_i factor derived from CN" -msgstr "" +msgstr "从CN导出的S_i因子图" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:422 msgid "Copy of LULC input, aligned and clipped to match the other spatial inputs" -msgstr "" +msgstr "LULC输入的副本,经过对齐和裁剪以匹配其他空间输入" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:427 msgid "Copy of DEM input, aligned and clipped to match the other spatial inputs" -msgstr "" +msgstr "DEM输入的副本,经过对齐和裁剪以匹配其他空间输入" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:432 msgid "Pit filled DEM" -msgstr "" +msgstr "填坑数字高程模型" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:436 -msgid "" -"Copy of soil groups input, aligned and clipped to match the other spatial" -" inputs" -msgstr "" +msgid "Copy of soil groups input, aligned and clipped to match the other spatial inputs" +msgstr "土壤组输入的副本,对齐并剪切以匹配其他空间输入" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:443 -msgid "" -"Monthly precipitation rasters, aligned and clipped to match the other " -"spatial inputs" -msgstr "" +msgid "Monthly precipitation rasters, aligned and clipped to match the other spatial inputs" +msgstr "月降水量栅格,对齐并裁剪以匹配其他空间输入" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:447 msgid "Map of monthly rain events" -msgstr "" +msgstr "每月降雨事件地图" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:452 msgid "Monthly ET0 rasters, aligned and clipped to match the other spatial inputs" -msgstr "" +msgstr "每月ET0栅格,对齐并裁剪以匹配其他空间输入" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:456 msgid "Map of monthly KC values" -msgstr "" +msgstr "每月KC值地图" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:460 -msgid "" -"Copy of user-defined local recharge input, aligned and clipped to match " -"the other spatial inputs" -msgstr "" +msgid "Copy of user-defined local recharge input, aligned and clipped to match the other spatial inputs" +msgstr "用户定义的本地充值输入的副本,已对齐并剪裁以匹配其他空间输入" #: src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py:465 -msgid "" -"Copy of user-defined climate zones raster, aligned and clipped to match " -"the other spatial inputs" -msgstr "" +msgid "Copy of user-defined climate zones raster, aligned and clipped to match the other spatial inputs" +msgstr "用户定义的气候区栅格的副本,经过对齐和裁剪以匹配其他空间输入" #~ msgid "LULC code corresponding to values in the LULC map." #~ msgstr "与LULC栅格中的值相对应的LULC代码。" -#~ msgid "" -#~ "LULC code. Every value in the LULC" -#~ " maps must have a corresponding entry" -#~ " in this column." +#~ msgid "LULC code. Every value in the LULC maps must have a corresponding entry in this column." #~ msgstr "LULC代码。LULC地图中的每一个值都必须在这一栏中有一个相应的条目。" -#~ msgid "" -#~ "Code for this LULC class from the" -#~ " LULC map. Every value in the " -#~ "LULC raster must have a corresponding" -#~ " entry in this column." +#~ msgid "Code for this LULC class from the LULC map. Every value in the LULC raster must have a corresponding entry in this column." #~ msgstr "从LULC中对应是代码。LULC栅格中的每个值在这一列中都必须有相应的条目。" #~ msgid "Use the predefined GLOBIO LULC map instead of providing the LULC map." @@ -4891,11 +4108,7 @@ msgstr "" #~ msgid "use predefined LULC" #~ msgstr "使用预定义的LULC" -#~ msgid "" -#~ "Each LULC code must have a " -#~ "corresponding entry in the biophysical " -#~ "table. Required if Use Predefined GLOBIO" -#~ " LULC is not selected." +#~ msgid "Each LULC code must have a corresponding entry in the biophysical table. Required if Use Predefined GLOBIO LULC is not selected." #~ msgstr "每个LULC代码必须在生物物理表中有一个相应的条目。如果不选择使用预定义GLOBIO LULC,则需要。" #~ msgid "LULC code from the LULC map input." @@ -4905,41 +4118,24 @@ msgstr "" #~ msgstr "相应的GLOBIO LULC代码。" #~ msgid "" -#~ "A table mapping each LULC code in" -#~ " the LULC raster input to the " -#~ "corresponding GLOBIO LULC code for the" -#~ " class. Required if Use Predefined " -#~ "GLOBIO LULC is not selected." -#~ msgstr "" -#~ "将LULC栅格输入中的每个LULC代码映射到该类的相应GLOBIO LULC代码的表格。如果没有选择使用预定义的GLOBIO" -#~ " LULC,则需要。" +#~ "A table mapping each LULC code in the LULC raster input to the corresponding GLOBIO LULC code for the class. Required if Use Predefined GLOBIO LULC is not selected." +#~ msgstr "将LULC栅格输入中的每个LULC代码映射到该类的相应GLOBIO LULC代码的表格。如果没有选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "LULC to GLOBIO LULC Table" #~ msgstr "LULC与GLOBIO LULC对应表" #~ msgid "" -#~ "Maps of the location of infrastructure." -#~ " For rasters, any valid value greater" -#~ " than zero indicates the presence of" -#~ " infrastrucutre. For vectors, any " -#~ "geometries indicate the presence of " -#~ "infrastructure." +#~ "Maps of the location of infrastructure. For rasters, any valid value greater than zero indicates the presence of infrastrucutre. For vectors, any geometries " +#~ "indicate the presence of infrastructure." #~ msgstr "基础设施位置的地图。对于栅格,任何大于零的有效值都表示有基础设施存在。对于矢量,任何几何图形都表示有基础设施存在。" -#~ msgid "" -#~ "Directory containing raster and/or vector " -#~ "map(s) any forms of infrastructure to" -#~ " consider in the MSA calculation." +#~ msgid "Directory containing raster and/or vector map(s) any forms of infrastructure to consider in the MSA calculation." #~ msgstr "包含栅格和/或矢量地图的目录,在MSA计算中考虑的任何形式的基础设施。" #~ msgid "infrastructure directory" #~ msgstr "基础设施目录" -#~ msgid "" -#~ "Map of the proportion of each " -#~ "pixel that is pasture. Required if " -#~ "Use Predefined GLOBIO LULC is not " -#~ "selected." +#~ msgid "Map of the proportion of each pixel that is pasture. Required if Use Predefined GLOBIO LULC is not selected." #~ msgstr "每个栅格的牧草比例图。如果不选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "pasture" @@ -4948,20 +4144,12 @@ msgstr "" #~ msgid "potential vegetation" #~ msgstr "潜在的植被" -#~ msgid "" -#~ "Map of potential vegetation classes from" -#~ " Ramankutty and Foley (1999). Required " -#~ "if Use Predefined GLOBIO LULC is " -#~ "not selected." +#~ msgid "Map of potential vegetation classes from Ramankutty and Foley (1999). Required if Use Predefined GLOBIO LULC is not selected." #~ msgstr "来自Ramankutty和Foley(1999)的潜在植被等级图。如果不选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "" -#~ "Areas in the Pasture map with a" -#~ " pasture proportion greater than or " -#~ "equal to this threshold are considered" -#~ " grassland or livestock grazing areas. " -#~ "Required if Use Predefined GLOBIO LULC" -#~ " is not selected." +#~ "Areas in the Pasture map with a pasture proportion greater than or equal to this threshold are considered grassland or livestock grazing areas. Required if Use " +#~ "Predefined GLOBIO LULC is not selected." #~ msgstr "牧场地图中牧场比例大于或等于该阈值的区域被视为草原或牲畜放牧区。如果不选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "pasture threshold" @@ -4974,81 +4162,43 @@ msgstr "" #~ msgstr "强化农业的比例" #~ msgid "" -#~ "Forest ragmentation quality index threshold" -#~ " below which an area is classified" -#~ " as secondary forest. Areas with FFQI" -#~ " greater than or equal to this " -#~ "threshold are classified as primary " -#~ "forest. Required if Use Predefined " -#~ "GLOBIO LULC is not selected." -#~ msgstr "" -#~ "森林破损质量指数阈值,低于此阈值的区域被归类为次生林。FFQI大于或等于该阈值的区域被划为原始森林。如果不选择使用预定义的GLOBIO" -#~ " LULC,则需要。" +#~ "Forest ragmentation quality index threshold below which an area is classified as secondary forest. Areas with FFQI greater than or equal to this threshold are " +#~ "classified as primary forest. Required if Use Predefined GLOBIO LULC is not selected." +#~ msgstr "森林破损质量指数阈值,低于此阈值的区域被归类为次生林。FFQI大于或等于该阈值的区域被划为原始森林。如果不选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "primary threshold" #~ msgstr "主要阈值" -#~ msgid "" -#~ "This MSA value represents infrastructure " -#~ "impacts on primary vegetation. The value" -#~ " in the 'value' column is a " -#~ "distance range in meters." +#~ msgid "This MSA value represents infrastructure impacts on primary vegetation. The value in the 'value' column is a distance range in meters." #~ msgstr "该MSA值表示基础设施对初级植被的影响。“value”列中的值是以米为单位的距离范围。" -#~ msgid "" -#~ "This MSA value represents infrastructure " -#~ "impacts on non-primary vegetation. The" -#~ " value in the 'value' column is " -#~ "a distance range in meters." +#~ msgid "This MSA value represents infrastructure impacts on non-primary vegetation. The value in the 'value' column is a distance range in meters." #~ msgstr "该MSA值表示基础设施对非原生植被的影响。“value”列中的值是以米为单位的距离范围。" -#~ msgid "" -#~ "This MSA value represents fragmentation " -#~ "impacts. The value in the 'value' " -#~ "column is an FFQI range." +#~ msgid "This MSA value represents fragmentation impacts. The value in the 'value' column is an FFQI range." #~ msgstr "这个MSA值表示碎片影响。“value”列中的值是一个FFQI范围。" -#~ msgid "" -#~ "This MSA value represents land-use " -#~ "impacts. The value in the 'value' " -#~ "column is one of the GLOBIO-" -#~ "recognized LULC codes." +#~ msgid "This MSA value represents land-use impacts. The value in the 'value' column is one of the GLOBIO-recognized LULC codes." #~ msgstr "这个MSA值表示土地使用的影响。“value”列中的值是GLOBIO识别的LULC代码之一。" #~ msgid "The type of MSA value in this row." #~ msgstr "该行中MSA值的类型。" #~ msgid "" -#~ "Indicates a number or range of a" -#~ " bin. This may be a single " -#~ "number e.g. 1000, a range (two " -#~ "numbers separated by a hyphen e.g. " -#~ "1000-2000), or an upper or lower " -#~ "bound (a number preceded by > or" -#~ " < e.g. <5" +#~ "Indicates a number or range of a bin. This may be a single number e.g. 1000, a range (two numbers separated by a hyphen e.g. 1000-2000), or an upper or lower bound " +#~ "(a number preceded by > or < e.g. <5" #~ msgstr "表示一个数字或一个bin的范围。这可以是一个单一的数字,如1000,一个范围(用连字符分隔的两个数字,如1000-2000),或一个上界或下界(前面有>或<的数字,如:<5" -#~ msgid "" -#~ "MSA value for the MSA type " -#~ "specified in the 'msa_type' column, when" -#~ " the impact value is within the " -#~ "range given in the 'value' column." +#~ msgid "MSA value for the MSA type specified in the 'msa_type' column, when the impact value is within the range given in the 'value' column." #~ msgstr "在'msa_type'列中指定的MSA类型的MSA值,当影响值在'value'列中给出的范围内。" -#~ msgid "" -#~ "Table that sets the MSA values for" -#~ " each impact driver and each range" -#~ " of impact values." +#~ msgid "Table that sets the MSA values for each impact driver and each range of impact values." #~ msgstr "为每个冲击器和每个冲击值范围设定MSA值的表格。" #~ msgid "MSA Parameter Table" #~ msgstr "MSA参数表" -#~ msgid "" -#~ "Predefined GLOBIO LULC map using the " -#~ "standard GLOBIO classification scheme and " -#~ "codes. Required if Use Predefined GLOBIO" -#~ " LULC is selected." +#~ msgid "Predefined GLOBIO LULC map using the standard GLOBIO classification scheme and codes. Required if Use Predefined GLOBIO LULC is selected." #~ msgstr "使用标准GLOBIO分类方案和代码的预定义GLOBIO LULC地图。如果选择使用预定义的GLOBIO LULC,则需要。" #~ msgid "GLOBIO Classified Land Use" @@ -5120,18 +4270,12 @@ msgstr "" #~ msgid "very low protection" #~ msgstr "极低保护" -#~ msgid "" -#~ "The column '{column_name}' was not found" -#~ " in the Threat Data table for " -#~ "the corresponding input LULC scenario." +#~ msgid "The column '{column_name}' was not found in the Threat Data table for the corresponding input LULC scenario." #~ msgstr "在相应的输入LULC情景的威胁数据表中没有找到\"{column_name}\"列。" #~ msgid "" -#~ "Map of the threat's distribution in " -#~ "the future scenario. Each pixel value" -#~ " is the relative intensity of the " -#~ "threat at that location. Required if " -#~ "Future LULC is provided." +#~ "Map of the threat's distribution in the future scenario. Each pixel value is the relative intensity of the threat at that location. Required if Future LULC is " +#~ "provided." #~ msgstr "威胁在未来场景中的分布图。每个像素值都是该位置威胁的相对强度。如果提供未来LULC,则必须。" #~ msgid "File could not be opened as a CSV or Excel file." @@ -5146,17 +4290,10 @@ msgstr "" #~ msgid "Maximum capacity for device." #~ msgstr "设备的最大容量。" -#~ msgid "" -#~ "Upper limit of wave height for " -#~ "device operation. The device shuts down" -#~ " when waves are higher than this." +#~ msgid "Upper limit of wave height for device operation. The device shuts down when waves are higher than this." #~ msgstr "设备运行的波浪高度的上限。当波浪高于这个高度时,设备就会关闭。" -#~ msgid "" -#~ "Upper limit of wave period for " -#~ "device operation. The device shuts down" -#~ " when the wave period is longer " -#~ "than this." +#~ msgid "Upper limit of wave period for device operation. The device shuts down when the wave period is longer than this." #~ msgstr "设备运行的波形周期的上限。当波浪周期长于此值时,设备就会关闭。" #~ msgid "Maximum capacity of the device." @@ -5185,4 +4322,3 @@ msgstr "" #~ msgid "Number of slack lines required per machine." #~ msgstr "每台机器需要的松弛线的数量。" - diff --git a/workbench/src/main/i18n/zh.json b/workbench/src/main/i18n/zh.json index 56b5f2b5b8..063a1f7b79 100644 --- a/workbench/src/main/i18n/zh.json +++ b/workbench/src/main/i18n/zh.json @@ -1,10 +1,10 @@ { - "File": "文件", - "Edit": "编辑", - "Speech": "语音输入", - "View": "视图", - "Window": "界面", - "About": "关于", - "About InVEST": "关于 InVEST", - "Report a problem": "报告一个问题" -} + "File": "文件", + "Edit": "编辑", + "Speech": "语音输入", + "View": "视图", + "Window": "界面", + "About": "关于", + "About InVEST": "关于 InVEST", + "Report a problem": "报告一个问题" +} \ No newline at end of file diff --git a/workbench/src/renderer/i18n/zh.json b/workbench/src/renderer/i18n/zh.json index a6ede53a83..88601e57fd 100644 --- a/workbench/src/renderer/i18n/zh.json +++ b/workbench/src/renderer/i18n/zh.json @@ -1,147 +1,147 @@ { - "Annual Water Yield": "", - "Carbon Storage and Sequestration": "", - "Coastal Blue Carbon": "", - "Coastal Vulnerability": "", - "Crop Pollination": "", - "Crop Production": "", - "DelineateIt": "", - "Forest Carbon Edge Effect": "", - "Habitat Quality": "", - "Habitat Risk Assessment": "", - "Nutrient Delivery Ratio": "", - "RouteDEM": "", - "Scenario Generator: Proximity Based": "", - "Scenic Quality": "", - "Seasonal Water Yield": "", - "Sediment Delivery Ratio": "", - "Urban Stormwater Retention": "", - "Urban Cooling": "", - "Urban Flood Risk Mitigation": "", - "Urban Nature Access": "", - "Visitation: Recreation and Tourism": "", - "Wave Energy Production": "", - "Wind Energy Production": "", - "Global DEM & Landmass Polygon": "", - "(recommended to run model)": "", - "(required to run model)": "", - "(required for Wind & Wave Energy)": "", - "Please choose a different folder. This application does not have permission to write to folder:": "", - "Download InVEST sample data": "下载InVEST样例数据", - "Cancel": "取消", - "Download": "下载", - "Download Failed": "下载失败", - "Download Complete": "下载完整版", - "Downloading {{number}} of {{nTotal}}": "下载{{nTotal}}个文件中的第{{number}}个", - "Something went wrong": "出了些问题", - "Please help us fix this by reporting the problem.You may follow these steps:": "请通过报告这个问题来帮助我们解决这个问题。你可以按照以下步骤进行:", - "Find the Workbench log files using the button below.": "请使用下面的按钮来查看工作台的日志文件。", - "There may be multiple files with a \".log\" extension.": "可能有多个以\".log \"为扩展名的文件。", - "Find My Logs": "寻找我的日志文件", - "Create a post on our forum ": "在我们的论坛上创建一个帖子", - "and upload all the log files, along with a brief description of what happened before you saw this message.": "并上传所有的日志文件。请同时简要描述在你看到这条信息之前发生的状况。", - "Model Complete": "模型运行完成", - "Recent runs:": "最近的运行:", - "Set up a model from a sample datastack file (.json) or from an InVEST model's logfile (.txt): ": "从示例数据堆栈文件 (.json) 或 InVEST 模型的日志文件 (.txt) 设置模型:", - "Setup": "设置", - "Log": "日志", - "Open Workspace": "打开工作空间", - "Cancel Run": "取消运行", - "Error: see log for details": "错误:详见日志", - "Run Canceled": "取消运行", - "No InVEST model data can be parsed from the file:": "", - "Browse to a datastack (.json) or InVEST logfile (.txt)": "浏览到一个数据包(.json)或InVEST日志文件(.txt)。", - "Open": "打开", - "User's Guide": "用户指南", - "Frequently Asked Questions": "常见问题", - "Save as...": "另存为…", - "Datastack options": "数据堆栈选项", - "Save your parameters in a JSON file. This includes the paths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "将参数保存在 JSON 文件中。 这包括输入数据的路径,但不包括数据本身。 在 InVEST 中打开此文件以恢复您的参数。", - "Save your parameters and input data in a compressed archive. This archive contains the same JSON file produced by the \"Parameters only\" option, plus the data. You can open this file in InVEST to restore your parameters. This option is useful to copy all the necessary data to a different location.": "将您的参数和输入数据保存在压缩存档中。 此压缩存档包含由“仅参数”选项生成的相同 JSON 文件以及数据。 您可以在 InVEST 模型中打开此文件以恢复您的参数。 此选项有助于将所有必要数据复制到不同位置。", - "Save your parameters in a python script. This includes the paths to your input data, but not the data itself. Running the python script will programmatically run the model with your parameters. Use this as a starting point for batch scripts.": "将参数保存在 python 脚本中。 这包括输入数据的路径,但不包括数据本身。 运行 python 脚本将以编程方式使用您的参数运行模型。 您可以基于此用脚本进行批处理。", - "Save": "保存", - "Synchronous": "同步", - "Threaded task management": "线程任务管理", - "CPUs": "处理器", - "DEBUG": "调试", - "INFO": "信息", - "WARNING": "警告", - "ERROR": "错误", - "InVEST Settings": "InVEST设置", - "Language": "语言", - "Logging threshold": "日志阈值", - "Taskgraph logging threshold": "任务图记录阈值", - "Taskgraph n_workers parameter": "任务图n_workers参数", - "more info": "更多信息", - "synchronous task execution is most reliable": "同步任务的执行是最可靠的", - "threaded task management: tasks execute only in the main process, using multiple threads.": "线程任务管理:任务只在主进程中使用多线程执行。", - "n CPUs: depending on the InVEST model, tasks may execute in parallel using up to this many processes.": "n CPU:根据 InVEST 模型,任务最多可以在这么多个进程下执行任务。", - "Download Sample Data": "下载样例数据", - "Clear Recent Jobs": "清除最近的工作", - "no invest workspaces will be deleted": "没有invest的工作空间将被删除", - "Warning": "", - "Changing this setting will close your tabs and relaunch the app.": "", - "Change to ": "", - "Not all of the spatial layers overlap each other. Bounding box:": "", - "optional": "可选项", - "boolean": "", - "integer": "整数", - "csv": "", - "directory": "模型数据目录", - "file": "文件后缀", - "freestyle_string": "", - "number": "数量", - "option_string": "", - "percent": "百分比", - "raster": "栅格", - "ratio": "比例", - "vector": "向量", - "text": "文本", - "percent: a number from 0 - 100": "百分比:一个从0-100的数字", - "ratio: a decimal from 0 - 1": "比率:一个从0-1的小数", - "User's guide entry": "用户指南条目", - "Only drop one file at a time.": "一次只能丢一个文件。", - "Choose location to extract archive": "", - "Datastack/Logfile for {{modelName}} does not match this model.": "{{modelName}} 个数据堆栈/日志文件与此模型不匹配。", - "Running": "运行中", - "Run": "运行", - "Browse to a datastack (.json, .tgz) or InVEST logfile (.txt)": "浏览到数据包(.json, .tgz)或InVEST日志文件(.txt)。", - "Load parameters from file": "从文件中加载参数", - "No args to see here": "在args dict中缺少关键信息", - "version:": "版本:", - "Copyright 2023, The Natural Capital Project": "", - "Documentation": "", - "Homepage": "", - "Project page": "", - "License": "", - "InVEST Trademark and Logo Use Policy": "", - "Open-Source Licenses:": "开源许可证:", - "MIT and others": "MIT许可证及其他许可证", - "Please help us by reporting problems.": "请通过报告问题来帮助我们。", - "If the problem is related to a specific InVEST model, ": "如果这个问题与特定的 InVEST 模型有关,", - "please see the guidelines here for reporting problems: ": "请查看此指南,然后上报问题:", - "Guidelines for posting software support questions": "发布软件支持问题的指南", - "If the problem is related to this User Interface, ": "如果问题与此用户界面有关,", - "rather than with a specific InVEST model,": "而不是与使用某个特定的 InVEST 模型有关,", - "Consider taking a screenshot of the problem.": "请截屏保存以便随后发布帖子寻求帮助。", - "Find the log files using the button below. There may be multiple files with a \".log\" extension; please include them all.": "使用下面的按钮查找日志文件。 可能有多个扩展名为“.log”的文件; 请把它们全部包括在内。", - "Create a post on our forum and upload these items, along with a brief description of the problem.": "在我们的论坛上创建一个帖子并上传这些项目以及问题的简要说明。", - "Changing this setting will refresh the app and close all tabs": "更改此设置将刷新应用程序并关闭所有选项卡", - "Reset to Defaults": "重置为默认值", - "Bounding box does not intersect at least one other:": "边界框至少不与另一个相交:", - "Copyright 2022, The Natural Capital Project": "版权所有 2022, The Natural Capital Project", - "Documentation: ": "文档:", - "Homepage: ": "主页:", - "Project page: ": "项目页面:", - "License: ": "许可证:", - "Export all input data to a compressed archive": "将所有输入数据导出到压缩档案中", - "InVEST": "InVEST", - "Save datastack": "保存数据包", - "Save model setup to a JSON file": "将模型设置保存到一个JSON文件中", - "Save model setup to a Python script": "将模型设置保存到Python脚本中", - "Save to JSON": "保存到JSON", - "Save to Python script": "保存到Python脚本", - "true/false": "真/假", - "CSV": "CSV", - "option": "选项" -} + "Annual Water Yield": "年出水量", + "Carbon Storage and Sequestration": "碳储存和碳封存", + "Coastal Blue Carbon": "海岸蓝碳", + "Coastal Vulnerability": "沿海地区的脆弱性", + "Crop Pollination": "作物授粉", + "Crop Production": "农作物生产", + "DelineateIt": "划线", + "Forest Carbon Edge Effect": "森林碳边效应", + "Habitat Quality": "生境质量", + "Habitat Risk Assessment": "生境风险评估", + "Nutrient Delivery Ratio": "营养输送比", + "RouteDEM": "路线高程", + "Scenario Generator: Proximity Based": "情景生成器:基于邻近性", + "Scenic Quality": "风景质量", + "Seasonal Water Yield": "季节产水量", + "Sediment Delivery Ratio": "沉积物输送比", + "Urban Stormwater Retention": "城市雨水滞留", + "Urban Cooling": "城市降温", + "Urban Flood Risk Mitigation": "城市洪水风险缓解", + "Urban Nature Access": "城市自然通道", + "Visitation: Recreation and Tourism": "参观:娱乐和旅游", + "Wave Energy Production": "波浪能生产", + "Wind Energy Production": "风能生产", + "Global DEM & Landmass Polygon": "全球 高程 和地块多边形", + "(recommended to run model)": "(建议运行模型)", + "(required to run model)": "(运行模型所需)", + "(required for Wind & Wave Energy)": "(风能和波浪能所需)", + "Please choose a different folder. This application does not have permission to write to folder:": "请选择其他文件夹。此应用程序没有写入文件夹的权限:", + "Download InVEST sample data": "下载InVEST样例数据", + "Cancel": "取消", + "Download": "下载", + "Download Failed": "下载失败", + "Download Complete": "下载完整版", + "Downloading {{number}} of {{nTotal}}": "下载{{nTotal}}个文件中的第{{number}}个", + "Something went wrong": "出了些问题", + "Please help us fix this by reporting the problem.You may follow these steps:": "请通过报告这个问题来帮助我们解决这个问题。你可以按照以下步骤进行:", + "Find the Workbench log files using the button below.": "请使用下面的按钮来查看工作台的日志文件。", + "There may be multiple files with a \".log\" extension.": "可能有多个以\".log \"为扩展名的文件。", + "Find My Logs": "寻找我的日志文件", + "Create a post on our forum ": "在我们的论坛上创建一个帖子", + "and upload all the log files, along with a brief description of what happened before you saw this message.": "并上传所有的日志文件。请同时简要描述在你看到这条信息之前发生的状况。", + "Model Complete": "模型运行完成", + "Recent runs:": "最近的运行:", + "Set up a model from a sample datastack file (.json) or from an InVEST model's logfile (.txt): ": "从示例数据堆栈文件 (.json) 或 InVEST 模型的日志文件 (.txt) 设置模型:", + "Setup": "设置", + "Log": "日志", + "Open Workspace": "打开工作空间", + "Cancel Run": "取消运行", + "Error: see log for details": "错误:详见日志", + "Run Canceled": "取消运行", + "No InVEST model data can be parsed from the file:": "无法从文件中解析 InVEST 模型数据:", + "Browse to a datastack (.json) or InVEST logfile (.txt)": "浏览到一个数据包(.json)或InVEST日志文件(.txt)。", + "Open": "打开", + "User's Guide": "用户指南", + "Frequently Asked Questions": "常见问题", + "Save as...": "另存为…", + "Datastack options": "数据堆栈选项", + "Save your parameters in a JSON file. This includes the paths to your input data, but not the data itself. Open this file in InVEST to restore your parameters.": "将参数保存在 JSON 文件中。 这包括输入数据的路径,但不包括数据本身。 在 InVEST 中打开此文件以恢复您的参数。", + "Save your parameters and input data in a compressed archive. This archive contains the same JSON file produced by the \"Parameters only\" option, plus the data. You can open this file in InVEST to restore your parameters. This option is useful to copy all the necessary data to a different location.": "将您的参数和输入数据保存在压缩存档中。 此压缩存档包含由“仅参数”选项生成的相同 JSON 文件以及数据。 您可以在 InVEST 模型中打开此文件以恢复您的参数。 此选项有助于将所有必要数据复制到不同位置。", + "Save your parameters in a python script. This includes the paths to your input data, but not the data itself. Running the python script will programmatically run the model with your parameters. Use this as a starting point for batch scripts.": "将参数保存在 python 脚本中。 这包括输入数据的路径,但不包括数据本身。 运行 python 脚本将以编程方式使用您的参数运行模型。 您可以基于此用脚本进行批处理。", + "Save": "保存", + "Synchronous": "同步", + "Threaded task management": "线程任务管理", + "CPUs": "处理器", + "DEBUG": "调试", + "INFO": "信息", + "WARNING": "警告", + "ERROR": "错误", + "InVEST Settings": "InVEST设置", + "Language": "语言", + "Logging threshold": "日志阈值", + "Taskgraph logging threshold": "任务图记录阈值", + "more info": "更多信息", + "synchronous task execution is most reliable": "同步任务的执行是最可靠的", + "threaded task management: tasks execute only in the main process, using multiple threads.": "线程任务管理:任务只在主进程中使用多线程执行。", + "n CPUs: depending on the InVEST model, tasks may execute in parallel using up to this many processes.": "n CPU:根据 InVEST 模型,任务最多可以在这么多个进程下执行任务。", + "Download Sample Data": "下载样例数据", + "Clear Recent Jobs": "清除最近的工作", + "no invest workspaces will be deleted": "没有invest的工作空间将被删除", + "Warning": "警告", + "Changing this setting will close your tabs and relaunch the app.": "更改此设置将关闭标签页并重新启动应用程序。", + "Change to ": "更改到", + "Not all of the spatial layers overlap each other. Bounding box:": "并非所有空间层都相互重叠。边界框:", + "optional": "可选项", + "boolean": "布尔值", + "integer": "整数", + "csv": "csv", + "directory": "模型数据目录", + "file": "文件后缀", + "number": "数量", + "percent": "百分比", + "raster": "栅格", + "ratio": "比例", + "vector": "向量", + "text": "文本", + "percent: a number from 0 - 100": "百分比:一个从0-100的数字", + "ratio: a decimal from 0 - 1": "比率:一个从0-1的小数", + "User's guide entry": "用户指南条目", + "Only drop one file at a time.": "一次只能丢一个文件。", + "Choose location to extract archive": "选择提取存档的位置", + "Datastack/Logfile for {{modelName}} does not match this model.": "{{modelName}} 个数据堆栈/日志文件与此模型不匹配。", + "Running": "运行中", + "Run": "运行", + "Browse to a datastack (.json, .tgz) or InVEST logfile (.txt)": "浏览到数据包(.json, .tgz)或InVEST日志文件(.txt)。", + "Load parameters from file": "从文件中加载参数", + "No args to see here": "在args dict中缺少关键信息", + "version:": "版本:", + "Copyright 2023, The Natural Capital Project": "版权所有 2023 年,自然资本项目", + "Documentation": "文档", + "Homepage": "首页", + "Project page": "项目页面", + "License": "许可证", + "InVEST Trademark and Logo Use Policy": "InVEST 商标和徽标使用政策", + "Open-Source Licenses:": "开源许可证:", + "MIT and others": "MIT许可证及其他许可证", + "Please help us by reporting problems.": "请通过报告问题来帮助我们。", + "If the problem is related to a specific InVEST model, ": "如果这个问题与特定的 InVEST 模型有关,", + "please see the guidelines here for reporting problems: ": "请查看此指南,然后上报问题:", + "Guidelines for posting software support questions": "发布软件支持问题的指南", + "If the problem is related to this User Interface, ": "如果问题与此用户界面有关,", + "rather than with a specific InVEST model,": "而不是与使用某个特定的 InVEST 模型有关,", + "Consider taking a screenshot of the problem.": "请截屏保存以便随后发布帖子寻求帮助。", + "Find the log files using the button below. There may be multiple files with a \".log\" extension; please include them all.": "使用下面的按钮查找日志文件。 可能有多个扩展名为“.log”的文件; 请把它们全部包括在内。", + "Create a post on our forum and upload these items, along with a brief description of the problem.": "在我们的论坛上创建一个帖子并上传这些项目以及问题的简要说明。", + "Changing this setting will refresh the app and close all tabs": "更改此设置将刷新应用程序并关闭所有选项卡", + "Reset to Defaults": "重置为默认值", + "Bounding box does not intersect at least one other:": "边界框至少不与另一个相交:", + "Copyright 2022, The Natural Capital Project": "版权所有 2022, The Natural Capital Project", + "Documentation: ": "文档:", + "Homepage: ": "主页:", + "Project page: ": "项目页面:", + "License: ": "许可证:", + "Export all input data to a compressed archive": "将所有输入数据导出到压缩档案中", + "InVEST": "InVEST", + "Save datastack": "保存数据包", + "Save model setup to a JSON file": "将模型设置保存到一个JSON文件中", + "Save model setup to a Python script": "将模型设置保存到Python脚本中", + "Save to JSON": "保存到JSON", + "Save to Python script": "保存到Python脚本", + "true/false": "真/假", + "CSV": "CSV", + "option": "选项", + "Taskgraph n_workers parameter": "任务图n_workers参数", + "freestyle_string": "自由式", + "option_string": "选项" +} \ No newline at end of file From 4634f745535eb16574c2315e76a101ba71815573 Mon Sep 17 00:00:00 2001 From: James Douglass Date: Tue, 8 Oct 2024 13:23:31 -0700 Subject: [PATCH 20/90] Reverting requirements conversion back to main. The build issues I was experiencing had nothing to do with the contents of this file. RE:#1635 --- scripts/convert-requirements-to-conda-yml.py | 52 +------------------- 1 file changed, 1 insertion(+), 51 deletions(-) diff --git a/scripts/convert-requirements-to-conda-yml.py b/scripts/convert-requirements-to-conda-yml.py index f3c6e51da2..e5e2bc2d57 100644 --- a/scripts/convert-requirements-to-conda-yml.py +++ b/scripts/convert-requirements-to-conda-yml.py @@ -2,7 +2,6 @@ """convert-requirements-to-conda-yml.py""" import argparse -import os import platform import sys @@ -15,46 +14,6 @@ """ -# Environment marker handling is taken straight from -# https://peps.python.org/pep-0508/#environment-markers -def _get_implementation_version(): - def format_full_version(info): - version = '{0.major}.{0.minor}.{0.micro}'.format(info) - kind = info.releaselevel - if kind != 'final': - version += kind[0] + str(info.serial) - return version - - if hasattr(sys, 'implementation'): - implementation_version = format_full_version( - sys.implementation.version) - else: - implementation_version = "0" - return implementation_version - - -# Environment marker handling is taken straight from -# https://peps.python.org/pep-0508/#environment-markers -ENV_MARKERS = { - "os_name": os.name, - "sys_platform": sys.platform, - "platform_machine": platform.machine(), - "platform_python_impl": platform.python_implementation(), - "platform_release": platform.release(), - "platform_system": platform.system(), - "platform_version": platform.version(), - - # Deliberately not supporting python_version marker in order to avoid - # possible issues with the python version not yet being known when this - # script is run. - # "python_version": '.'.join(platform.python_version_tuple()[:2]), - - "python_full_version": platform.python_version(), - "implementation_name": sys.implementation.name, - "implementation_version": _get_implementation_version(), -} - - def build_environment_from_requirements(cli_args): """Build a conda environment.yml from requirements.txt files. @@ -103,16 +62,7 @@ def build_environment_from_requirements(cli_args): # requirement if we're using pip. conda_requirements.add('pip') - # Handle environment specifiers and see if the requirement - # should exist in this environment. - # InVEST pretty much just uses this for checking operating - # systems. - if ";" in line: - package, marker = line.split(';') - if eval(marker, ENV_MARKERS): - pip_requirements.add(package) - else: - pip_requirements.add(line) + pip_requirements.add(line) # If an scm needs to be installed for pip to clone to a # revision, add it to the conda package list. From 8165704ba2d3a178298694bcaad457c3097920bc Mon Sep 17 00:00:00 2001 From: James Douglass Date: Wed, 9 Oct 2024 14:31:58 -0700 Subject: [PATCH 21/90] Restoring a comment in UNA. RE:#1635 --- src/natcap/invest/urban_nature_access.py | 1 + 1 file changed, 1 insertion(+) diff --git a/src/natcap/invest/urban_nature_access.py b/src/natcap/invest/urban_nature_access.py index 4c8261cc5e..136575a956 100644 --- a/src/natcap/invest/urban_nature_access.py +++ b/src/natcap/invest/urban_nature_access.py @@ -2548,6 +2548,7 @@ def _warp_lulc(source_lulc_path, target_lulc_path, target_pixel_size, 'near', target_bb=target_bounding_box, target_projection_wkt=source_raster_info['projection_wkt']) + # if there is no defined nodata, set a default value if target_nodata is None: # Guarantee that our nodata cannot be represented by the datatype - # select a nodata value that's out of range. From e1698aba6e06bd2e8bc0c93351d5ff631c494206 Mon Sep 17 00:00:00 2001 From: davemfish Date: Tue, 22 Oct 2024 08:50:23 -0400 Subject: [PATCH 22/90] move a test to be near other related tests. #1657 --- tests/test_coastal_vulnerability.py | 84 ++++++++++++++--------------- 1 file changed, 42 insertions(+), 42 deletions(-) diff --git a/tests/test_coastal_vulnerability.py b/tests/test_coastal_vulnerability.py index 0b3be853a2..7cfcd9cb13 100644 --- a/tests/test_coastal_vulnerability.py +++ b/tests/test_coastal_vulnerability.py @@ -1358,6 +1358,48 @@ def test_aoi_invalid_geometry(self): aoi_path, landmass_path, model_resolution, target_vector_path, polygon_pickle, lines_pickle, lines_rtree) + def test_prepare_landmass_invalid_geometry(self): + """CV: test handling invalid geometries in landmass vector.""" + from natcap.invest import coastal_vulnerability + aoi_path = os.path.join(self.workspace_dir, 'aoi.geojson') + srs = osr.SpatialReference() + srs.ImportFromEPSG(26910) # UTM Zone 10N + wkt = srs.ExportToWkt() + + aoi_geometries = [Polygon([ + (-200, -200), (200, -200), (200, 200), (-200, 200), (-200, -200)])] + pygeoprocessing.shapely_geometry_to_vector( + aoi_geometries, aoi_path, wkt, 'GeoJSON') + + landmass_vector_path = os.path.join(self.workspace_dir, 'vector.gpkg') + n_features = make_vector_of_invalid_geoms(landmass_vector_path) + + target_polygon_pickle_path = os.path.join( + self.workspace_dir, 'polygon.pickle') + target_lines_pickle_path = os.path.join( + self.workspace_dir, 'lines.pickle') + target_rtree_path = os.path.join(self.workspace_dir, 'rtree.dat') + # Create rtree files to exercise the function's logic of removing + # pre-exisiting files + target_rtree_path_base = os.path.splitext(target_rtree_path)[0] + open(target_rtree_path, 'a').close() + open(target_rtree_path_base + '.idx', 'a').close() + + model_resolution = 100 + target_vector_path = os.path.join( + self.workspace_dir, 'temp-shore-pts.gpkg') + coastal_vulnerability.prepare_landmass_line_index_and_interpolate_shore_points( + aoi_path, landmass_vector_path, model_resolution, + target_vector_path, target_polygon_pickle_path, + target_lines_pickle_path, target_rtree_path) + + with open(target_polygon_pickle_path, 'rb') as polygon_file: + shapely_geom = pickle.load(polygon_file) + + # Expect 1 input geometry to be skipped, and the rest to be in + # shapely_geom_list. + self.assertTrue(len(shapely_geom.geoms) == n_features - 1) + def test_no_wwiii_coverage(self): """CV: test exception when shore points are outside max wwiii dist.""" from natcap.invest import coastal_vulnerability @@ -1434,48 +1476,6 @@ def test_projected_wwiii_input(self): layer = None vector = None - def test_prepare_landmass_invalid_geometry(self): - """CV: test handling invalid geometries in landmass vector.""" - from natcap.invest import coastal_vulnerability - aoi_path = os.path.join(self.workspace_dir, 'aoi.geojson') - srs = osr.SpatialReference() - srs.ImportFromEPSG(26910) # UTM Zone 10N - wkt = srs.ExportToWkt() - - aoi_geometries = [Polygon([ - (-200, -200), (200, -200), (200, 200), (-200, 200), (-200, -200)])] - pygeoprocessing.shapely_geometry_to_vector( - aoi_geometries, aoi_path, wkt, 'GeoJSON') - - landmass_vector_path = os.path.join(self.workspace_dir, 'vector.gpkg') - n_features = make_vector_of_invalid_geoms(landmass_vector_path) - - target_polygon_pickle_path = os.path.join( - self.workspace_dir, 'polygon.pickle') - target_lines_pickle_path = os.path.join( - self.workspace_dir, 'lines.pickle') - target_rtree_path = os.path.join(self.workspace_dir, 'rtree.dat') - # Create rtree files to exercise the function's logic of removing - # pre-exisiting files - target_rtree_path_base = os.path.splitext(target_rtree_path)[0] - open(target_rtree_path, 'a').close() - open(target_rtree_path_base + '.idx', 'a').close() - - model_resolution = 100 - target_vector_path = os.path.join( - self.workspace_dir, 'temp-shore-pts.gpkg') - coastal_vulnerability.prepare_landmass_line_index_and_interpolate_shore_points( - aoi_path, landmass_vector_path, model_resolution, - target_vector_path, target_polygon_pickle_path, - target_lines_pickle_path, target_rtree_path) - - with open(target_polygon_pickle_path, 'rb') as polygon_file: - shapely_geom = pickle.load(polygon_file) - - # Expect 1 input geometry to be skipped, and the rest to be in - # shapely_geom_list. - self.assertTrue(len(shapely_geom.geoms) == n_features - 1) - def test_clip_project_already_projected_raster(self): """CV: test clip_and_project_raster on an already projected raster.""" from natcap.invest import coastal_vulnerability From 2b956f9f689a79f51a793b28b79eefbdd032b1d1 Mon Sep 17 00:00:00 2001 From: davemfish Date: Tue, 22 Oct 2024 09:29:45 -0400 Subject: [PATCH 23/90] fixed a shapely 2.0 incompatibility; modified a test to cover it. #1657 --- HISTORY.rst | 18 +++++++++++------- src/natcap/invest/coastal_vulnerability.py | 22 ++++++++-------------- tests/test_coastal_vulnerability.py | 9 +++++++-- 3 files changed, 26 insertions(+), 23 deletions(-) diff --git a/HISTORY.rst b/HISTORY.rst index a8bcf05148..71214591b0 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -44,13 +44,6 @@ Unreleased Changes ``pygeoprocessing.get_raster_info`` and ``pygeoprocessing.get_vector_info``. https://github.com/natcap/invest/issues/1645 -* Forest Carbon Edge Effects - * Updating vector reprojection to allow partial reprojection. Related to - https://github.com/natcap/invest/issues/1645 -* Urban Nature Access - * The model now works as expected when the user provides an LULC raster - that does not have a nodata value defined. - https://github.com/natcap/invest/issues/1293 * Workbench * Several small updates to the model input form UI to improve usability and visual consistency (https://github.com/natcap/invest/issues/912). @@ -64,6 +57,13 @@ Unreleased Changes (https://github.com/natcap/invest/issues/1609). * Improved error handling when a datastack cannot be saved with relative paths across drives (https://github.com/natcap/invest/issues/1608). +* Coastal Vulnerability + * Fixed a regression where an AOI with multiple features could raise a + TypeError after intersecting with the landmass polygon. + https://github.com/natcap/invest/issues/1657 +* Forest Carbon Edge Effects + * Updating vector reprojection to allow partial reprojection. Related to + https://github.com/natcap/invest/issues/1645 * Habitat Quality * Access raster is now generated from the reprojected access vector (https://github.com/natcap/invest/issues/1615). @@ -72,6 +72,10 @@ Unreleased Changes * Urban Flood Risk * Fields present on the input AOI vector are now retained in the output. (https://github.com/natcap/invest/issues/1600) +* Urban Nature Access + * The model now works as expected when the user provides an LULC raster + that does not have a nodata value defined. + https://github.com/natcap/invest/issues/1293 3.14.2 (2024-05-29) ------------------- diff --git a/src/natcap/invest/coastal_vulnerability.py b/src/natcap/invest/coastal_vulnerability.py index ff30d3a24e..a1637451a6 100644 --- a/src/natcap/invest/coastal_vulnerability.py +++ b/src/natcap/invest/coastal_vulnerability.py @@ -21,6 +21,7 @@ from osgeo import gdal from osgeo import ogr from osgeo import osr +from shapely.geometry import LineString, MultiLineString from shapely.geometry.base import BaseMultipartGeometry from shapely.strtree import STRtree @@ -1104,7 +1105,6 @@ def prepare_landmass_line_index_and_interpolate_shore_points( # Get shapely geometries from landmass landmass_polygon_shapely_list = _ogr_to_geometry_list(landmass_vector_path) landmass_shapely = shapely.ops.unary_union(landmass_polygon_shapely_list) - landmass_polygon_shapely_list = None # store polygon geom for point-in-poly check later in ray-casting @@ -1170,19 +1170,13 @@ def prepare_landmass_line_index_and_interpolate_shore_points( if aoi_shapely_prepped.intersects(landmass_line): intersected_shapely_geom = aoi_shapely.intersection( landmass_line) - if intersected_shapely_geom.geom_type == 'LineString': - lines_in_aoi_list.append(intersected_shapely_geom) - elif intersected_shapely_geom.geom_type == 'MultiLineString': - shapely_geom_explode = [ - shapely.geometry.LineString(x) - for x in intersected_shapely_geom] - - lines_in_aoi_list.extend(shapely_geom_explode) - else: - # intersection could generate a point geom - # or if somehow the intersection is empty, - # type will be GeometryCollection. - continue + # intersection could generate a point geom, + # or if somehow the intersection is empty, + # type will be GeometryCollection. + if isinstance(intersected_shapely_geom, + (LineString, MultiLineString)): + lines_in_aoi_list.extend( + _list_geometry(intersected_shapely_geom)) # if none of the lines were disjoint before this linemerge, # unioned_line will now be a LineString. diff --git a/tests/test_coastal_vulnerability.py b/tests/test_coastal_vulnerability.py index 7cfcd9cb13..506d9b478f 100644 --- a/tests/test_coastal_vulnerability.py +++ b/tests/test_coastal_vulnerability.py @@ -1184,17 +1184,22 @@ def test_zero_shorepoints_created(self): def test_aoi_multiple_features(self): """CV: test shore point creation in AOI with multiple features.""" from natcap.invest import coastal_vulnerability - workspace_dir = self.workspace_dir + # workspace_dir = self.workspace_dir + workspace_dir = 'scratch/cv_test' aoi_path = os.path.join(workspace_dir, 'aoi.geojson') srs = osr.SpatialReference() srs.ImportFromEPSG(26910) # UTM Zone 10N wkt = srs.ExportToWkt() + # These two disjoint AOI polygons intersect the same landmass line + # segment. This tests an edge case where a MultiLineString + # geometry is created when landmass lines are clipped by the AOI. poly_a = Polygon([ (-200, -200), (-100, -200), (-100, -100), (-200, -100), (-200, -200)]) poly_b = Polygon([ - (100, 100), (200, 100), (200, 200), (100, 200), (100, 100)]) + (100, -200), (200, -200), (200, -100), (100, -100), + (100, -200)]) pygeoprocessing.shapely_geometry_to_vector( [poly_a, poly_b], aoi_path, wkt, 'GeoJSON') From b5a681b4e2f8d2ac788a72df332066f187d1376f Mon Sep 17 00:00:00 2001 From: davemfish Date: Tue, 22 Oct 2024 09:30:21 -0400 Subject: [PATCH 24/90] reverting a change for debugging. #1657 --- tests/test_coastal_vulnerability.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/tests/test_coastal_vulnerability.py b/tests/test_coastal_vulnerability.py index 506d9b478f..a6e6f60887 100644 --- a/tests/test_coastal_vulnerability.py +++ b/tests/test_coastal_vulnerability.py @@ -1184,8 +1184,7 @@ def test_zero_shorepoints_created(self): def test_aoi_multiple_features(self): """CV: test shore point creation in AOI with multiple features.""" from natcap.invest import coastal_vulnerability - # workspace_dir = self.workspace_dir - workspace_dir = 'scratch/cv_test' + workspace_dir = self.workspace_dir aoi_path = os.path.join(workspace_dir, 'aoi.geojson') srs = osr.SpatialReference() From 7846c2b87c48aa3387b9673a4baf164c1e67c634 Mon Sep 17 00:00:00 2001 From: James Douglass Date: Wed, 23 Oct 2024 11:01:52 -0700 Subject: [PATCH 25/90] Updating Scripting page of the API docs. RE:#1660 --- HISTORY.rst | 4 + doc/api-docs/scripting.rst | 222 +++++++++---------- doc/api-docs/scripting/modal_save_as.png | Bin 0 -> 323160 bytes doc/api-docs/scripting/workbench_save_as.png | Bin 0 -> 170450 bytes 4 files changed, 105 insertions(+), 121 deletions(-) create mode 100644 doc/api-docs/scripting/modal_save_as.png create mode 100644 doc/api-docs/scripting/workbench_save_as.png diff --git a/HISTORY.rst b/HISTORY.rst index 71214591b0..5eb71f8807 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -44,6 +44,10 @@ Unreleased Changes ``pygeoprocessing.get_raster_info`` and ``pygeoprocessing.get_vector_info``. https://github.com/natcap/invest/issues/1645 + * The scripting page of the InVEST API documentation has been updated to + reflect changes in how InVEST is installed on modern systems, and also to + include images of the InVEST workbench instead of just broken links. + https://github.com/natcap/invest/issues/1660 * Workbench * Several small updates to the model input form UI to improve usability and visual consistency (https://github.com/natcap/invest/issues/912). diff --git a/doc/api-docs/scripting.rst b/doc/api-docs/scripting.rst index 393ddd2ef4..b7c153d6e9 100644 --- a/doc/api-docs/scripting.rst +++ b/doc/api-docs/scripting.rst @@ -20,54 +20,18 @@ InVEST models from the command-line. Setting up your Python environment ================================== -1. **Install Python 3.6 or later.** +We recommend using the ``conda`` or ``mamba`` package manager to create an +environment. The easiest way to do so is to execute the following command:: - Python can be `downloaded from here `_. When installing, - be sure to allow ``python.exe`` to be added to the path in the installation options. + mamba create -n invest-env -c conda-forge natcap.invest +This will create a new environment called ``invest-env`` with the latest +released versions of python and ``natcap.invest``, as well as all dependencies +needed to execute ``natcap.invest``. -2. **Put pip on the PATH.** - - The ``pip`` utility for installing python packages is already included with - Python 2.7.9 and later. Be sure to add ``C:\Python37\Scripts`` (or your custom - install location) to the Windows PATH environment variable so that ``pip`` can - be called from the command line without needing to use its full path. - - After this is done (and you've opened a new command-line window), you will be - able to use ``pip`` at the command-line to install packages like so:: - - > pip install - -3. **Install packages needed to run InVEST.** - - Most (maybe even all) of these packages can be downloaded as precompiled - wheels from `Christoph Gohlke's build page `_. - Others should be able to be installed via ``pip install ``. - - .. This ..include:: part will automatically pull the contents of requirements.txt - and include the file from line 9 through the end. - - .. include:: ../../requirements.txt - :literal: - :start-line: 9 - - -4. **Install the InVEST python package** - - 4a. Download a release of the ``natcap.invest`` python package. - - * `Releases on the python package index `_ - - 4b. Install the downloaded python package.. - - * ``win32.whl`` files are prebuilt binary distributions and can be - installed via pip. - See the `pip docs for installing a package from a wheel - `_ - * ``.zip`` and ``.tar.gz`` files are source archives. - See :ref:`installing` for details, including how to - install specific development versions of ``natcap.invest``. - +Alternate installation methods are available. Please see the :ref:`installing` +guide for further instructions on setting up your python environment and +installing the ``natcap.invest`` package. .. _CreatingSamplePythonScripts: @@ -75,43 +39,52 @@ Setting up your Python environment Creating Sample Python Scripts ============================== -1. **Launch InVEST Model** +1. **Launch InVEST Workbench and Open the Selected Model** - Once an InVEST model is selected for scripting, - launch that model from the Windows Start menu. This example in this guide - follows the NDR model. + Once you have selected an InVEST model to script, launch the workbench and + select the model from the list of available models. This guide will follow + the Nutrient Delivery Ratio (NDR) model. 2. **Fill in InVEST Model Input Parameters** Once the user interface loads, populate the inputs in the model likely to be used in the Python script. For testing purposes the default InVEST’s - data is appropriate. However, if a user wishes to write a batch for several - InVEST runs, it would be reasonable to populate the user interface with - data for the first run. + data is appropriate. However, if you wish to write a script to execute + several InVEST model runs in sequence, it would be reasonable to populate + the user interface with data for the first run in the sequence. 3. **Generate a sample Python Script from the User Interface** - Open the Development menu at the top of the user interface and select - *"Save to python script..."* and save the file to a known location. + In the model interface, select *"Save as..."* in the left-hand menu bar, + *"Python script"* in the dialog box, and then save the file to a known location. -|2w7pilj.png| + |workbench_save_as.png| + |modal_save_as.png| -.. |2w7pilj.png| image:: https://bitbucket.org/repo/ag8qdk/images/3205488039-2w7pilj.png +.. |workbench_save_as.png| image:: scripting/workbench_save_as.png +.. |modal_save_as.png| image:: scripting/modal_save_as.png 4. **Execute the script in the InVEST Python Environment** - Launch a Windows PowerShell from the Start menu (type “powershell” in the - search box), then invoke the Python interpreter on the InVEST Python - script from that shell. In this example the Python interpreter is - installed in ``C:\Python37\python.exe`` and the script was saved in - ``C:\Users\rpsharp\Desktop\ndr.py``, thus the command to invoke the - interpreter is:: + Launch a shell of your choice and activate your InVEST environment you + created earlier. We will use the Windows command prompt ``cmd.exe`` for an + example, but the same commands should work on Powershell, bash and zsh. If + you created an environment called ``invest-env``, you would activate it with + ``conda`` like so:: - > C:\Python37\python.exe C:\Users\rpsharp\Desktop\ndr.py + > conda activate invest-env -|34ecba0.png| + You will know your environment activated correctly when you see the + environment name at the beginning of your shell prompt. For example:: -.. |34ecba0.png| image:: https://bitbucket.org/repo/ag8qdk/images/2939811460-34ecba0.png + (invest-env) C:\Users\demo > + + Once the environment has been activated, we can run the python script we + saved in the previous step. Suppose we're on Windows and the script was + saved to ``C:\Users\demo\Desktop\ndr.py``, the command to run the script + would be:: + + (invest-env) C:\Users\demo > python C:\Users\demo\Desktop\ndr.py 5. **Output Results** @@ -133,50 +106,68 @@ For reference, consider the following script generated by the Nutrient model wit .. code-block:: python - """ - This is a saved model run from natcap.invest.ndr.ndr. - Generated: Mon 16 May 2016 03:52:59 PM - InVEST version: 3.3.0 - """ + # coding=UTF-8 + # ----------------------------------------------- + # Generated by InVEST 3.14.2 on Wed Oct 23 10:49:40 2024 + # Model: Nutrient Delivery Ratio + + import logging + import sys import natcap.invest.ndr.ndr + import natcap.invest.utils + + LOGGER = logging.getLogger(__name__) + root_logger = logging.getLogger() + + handler = logging.StreamHandler(sys.stdout) + formatter = logging.Formatter( + fmt=natcap.invest.utils.LOG_FMT, + datefmt='%m/%d/%Y %H:%M:%S ') + handler.setFormatter(formatter) + logging.basicConfig(level=logging.INFO, handlers=[handler]) args = { - u'k_param': u'2', - u'runoff_proxy_uri': u'C:\InVEST_3.3.0_x86\Base_Data\Freshwater\precip', - u'subsurface_critical_length_n': u'150', - u'subsurface_critical_length_p': u'150', - u'subsurface_eff_n': u'0.8', - u'subsurface_eff_p': u'0.8', - u'threshold_flow_accumulation': u'1000', - u'biophysical_table_uri': u'C:\InVEST_3.3.0_x86\WP_Nutrient_Retention\Input\water_biophysical_table.csv', - u'calc_n': True, - u'calc_p': True, - u'suffix': '', - u'dem_uri': u'C:\InVEST_3.3.0_x86\Base_Data\Freshwater\dem', - u'lulc_uri': u'C:\InVEST_3.3.0_x86\Base_Data\Freshwater\landuse_90', - u'watersheds_uri': u'C:\InVEST_3.3.0_x86\Base_Data\Freshwater\watersheds.shp', - u'workspace_dir': u'C:\InVEST_3.3.0_x86\ndr_workspace', + 'biophysical_table_path': 'C:\\Users\demo\invest-sample-data\\NDR\\biophysical_table_gura.csv', + 'calc_n': True, + 'calc_p': True, + 'dem_path': 'C:\\Users\demo\invest-sample-data\\NDR\\DEM_gura.tif', + 'k_param': '2', + 'lulc_path': 'C:\\Users\demo\invest-sample-data\\NDR\land_use_gura.tif', + 'results_suffix': 'gura', + 'runoff_proxy_path': 'C:\\Users\demo\invest-sample-data\\NDR\precipitation_gura.tif', + 'subsurface_critical_length_n': '200', + 'subsurface_eff_n': '0.8', + 'threshold_flow_accumulation': '1000', + 'watersheds_path': 'C:\\Users\demo\invest-sample-data\\NDR\watershed_gura.shp', + 'workspace_dir': 'C:\\Users\demo\invest-sample-data\\NDR\workspace', } if __name__ == '__main__': natcap.invest.ndr.ndr.execute(args) -Elements to note: - -* *Parameter Python Dictionary*: Key elements include the ``‘args’`` dictionary. Note the similarities between the key values such as ``‘workspace_dir’`` and the equivalent “Workspace” input parameter in the user interface. Every key in the ``‘args’`` dictionary has a corresponding reference in the user interface. -|95zj7p.png| +Elements to note: -.. |95zj7p.png| image:: https://bitbucket.org/repo/ag8qdk/images/22613179-95zj7p.png +* *Parameter Python Dictionary*: Key elements include the ``'args'`` + dictionary. Note the similarities between the key values such as + ``'workspace_dir'`` and the equivalent "Workspace" input parameter in the + user interface. Every key in the ``'args'`` dictionary has a corresponding + reference in the user interface. -In the example below we’ll modify the script to execute the nutrient model for a parameter study of ``‘threshold_flow_accumulation’.`` + In the example below we’ll modify the script to execute the nutrient model + for a parameter study of ``'threshold_flow_accumulation'``. -* *Execution of the InVEST model*: The InVEST API invokes models with a consistent syntax where the module name that contains the InVEST model is listed first and is followed by a function called ‘execute’ that takes a single parameter called ``‘args’``. This parameter is the dictionary of input parameters discussed above. In this example, the line +* *Execution of the InVEST model*: The InVEST API invokes models with a + consistent syntax where the module name that contains the InVEST model is + listed first and is followed by a function called ‘execute’ that takes a + single parameter called ``'args'``. This parameter is the dictionary of input + parameters discussed above. In this example, the line :: -``natcap.invest.ndr.ndr.execute(args)`` + natcap.invest.ndr.ndr.execute(args) -executes the nutrient model end-to-end. If the user wishes to make batch calls to InVEST, this line will likely be placed inside a loop. + executes the nutrient model end-to-end. If the user wishes to make batch + calls to InVEST, this line will likely be placed inside a loop. ==================================================== Example: Threshold Flow Accumulation Parameter Study @@ -212,7 +203,7 @@ example, replace the last line in the UI generated Python script with: .. code-block:: python import os - landcover_dir = r'C:\User\Rich\Desktop\landcover_data' + landcover_dir = r'C:\User\demo\Desktop\landcover_data' if __name__ == '__main__': #Loop over all the filenames in the landcover dir @@ -225,43 +216,31 @@ example, replace the last line in the UI generated Python script with: natcap.invest.ndr.ndr.execute(args) This loop covers all the files located in -``C:\User\Rich\Desktop\landcover_data`` -and updates the relevant ``lulc_uri`` key in the args dictionary to each -of those files during execution as well as making a useful suffix so output -files can be distinguished from each other. +``C:\User\demo\Desktop\landcover_data`` and updates the relevant ``lulc_uri`` +key in the args dictionary to each of those files during execution as well as +making a useful suffix so output files can be distinguished from each other. ============================================ Example: Saving model log messages to a file ============================================ -There are many cases where you may want or need to capture all of the log -messages generated by the model. When we run models through the InVEST user -interface application, the UI captures all of this logging and saves it to a -logfile. We can replicate this behavior through the python logging package, -by adding the following code just after the ``import`` statements in the -example script. - +When you save a model run to a python script, InVEST will automatically include +code to write all logging to your console while it executes. But sometimes, +it's useful to save log messages from th emodel to a file. This can be done by +adding a few lines of code to the script, just after the existing logging +code: .. code-block:: python - import logging - import pygeoprocessing - - # Write all NDR log messages to logfile.txt - MODEL_LOGGER = logging.getLogger('natcap.invest.ndr') - handler = logging.FileHandler('logfile.txt') - MODEL_LOGGER.addHandler(handler) - - # log pygeoprocessing messages to the same logfile - PYGEO_LOGGER = logging.getLogger('pygeoprocessing') - PYGEO_LOGGER.addHandler(handler) + file_handler = logging.FileHandler('logfile.txt') + root_logger.addHandler(file_handler) -This will capture all logging generated by the ``ndr`` model and by -``pygeoprocessing``, writing all messages to ``logfile.txt``. While +This will capture all logging generated by any python package that executes +while running the ``ndr`` model writing all messages to ``logfile.txt``. While this is a common use case, the ``logging`` package provides functionality for many more complex logging features. For more advanced use of the python logging module, refer to the Python project's -`Logging Cookbook `_ +`Logging Cookbook `_ ===================================== Example: Enabling Parallel Processing @@ -306,7 +285,8 @@ Using the parameter study example, this might look like: Internationalization ==================== -If you use the InVEST python API to access model names, ``MODEL_SPEC``s, or validation messages, you can translate those strings using ``gettext``: +If you use the InVEST python API to access model names, ``MODEL_SPEC`` s, or +validation messages, you can translate those strings using ``gettext``: .. code-block:: python diff --git a/doc/api-docs/scripting/modal_save_as.png b/doc/api-docs/scripting/modal_save_as.png new file mode 100644 index 0000000000000000000000000000000000000000..b5f84c1bade2f0f09911ed7f98219daf493caa67 GIT binary patch literal 323160 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

Y3`0LP>pA%YY*nRBCvCC3jo(ejMhE$ifXh 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 z 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 z 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�>gY40i8@ObFMU7>5e=lq!+2r80xaJo{<1ZS%7($mD8 zB~V!r`?fLbD@RKkYMv-z$Vx}XS8@>zgsOERA+DPcR5(0CZ$kJ%%#8y zAz)E1;ay!zFbuXJ#6wzt=t@=5$eGi)3n6lqTky+1OOY@w>mz2Axx@Fr*H&c63Dt}?l}v?;JU!~pRqKs)YgS+!K)bYBwC zC`do)%`I)#U|FeaSrhU8qLcr_Q2xYC^YD|7Yytgy<)6O+Sw-K5ZuKN-K_2(+HJ~r7 zYw>%yV(5V;q_`DDpJ4Q^t*UhqCF%7NBARcUE1b8H=OQAh7d{?G$uhm3ua%Ar$+t2R z+D<`7oMd3=$?4+KyXJD<+(&U6hL6P*`*7-if8m2hBU=6SU>k9t zg;QnW3#%xRl2uASiz-uh*%6MsQdw8O6&@{b^27fvt^ZW#LcvhR!%1rEO;biyy5ACl z-1NL~V)k%_R;5EaBr9P%P4kEmK_g$7w@P#v06D5|E$m~^xwmUjWdGXrsu?AMw#D7J z>H+HA*VE;Uk&XBfP-O7jLdM-d2^pj}OTi3r{f{3nIz?jh%y{G=hzo#XZo4J9!HMpd|cRtiB_uHS!&ahRb({1cfo@SA#@vO|FWAEh#nudsi z>Ih@Ot^2%6n9i{=A-8Q*(Oh}{xE-Bpj+KOYb`SS6F2jE}x4@d5eEVIbtc(~QAt-Mj z7Q+$Ar|fc$3KvMiaF9w+X9%rc8ZNakukga=c=I*bXAJu_wm=F|klsX8&>nv;Xo)U% zWW-tLr^Zg6Z}~KVd(&o6+XrH}{(62mTRhJqjn5&S@}O@XeUn3ct&B_36Zh!6vwxz*Hp_@XrOj)Y~z`b1yvB(wP7pQ)}+_xaBg{OZUe=| zBOC<1rP>WT?Ol4FD%k^(BKUH<%unABln~4nV^Tpe0H{*NiPLqqRFC+8(_vLTmphz) zSa{fxy6mE9cY3Lu7>f9hMoP)(KHfXq&1iXsqX;HZ15RJ5Qm?8!c`tU0>E7*B&n=JX zA~h`rP>vL+7xeVV>Ad=Nn~bw|k9w*sZV^mIJ=~#cgG4B-EFmHgCw< z5D`yqwdE=`7$G(K;#7roGl^LVWoA5Am~%H`TDxY;P)WU1DpY@>An3?lHru(MFs}Zf zu%fZwN`}WY$ma{(<|Stj0mp4`hSVm}QRijXawHM|jcB~xe5j#VZA-b|KSIF?L7$;; z=rn5B=2J?v8pVO&X2t@$T3=sZI1=8pXeBZ}ml*ns7nut~R-2V00?}t9g1qww8rC=7 znl8InnG5t*MguYQ5%Kkz{nmbOUhPiiR|54$)~z~)%eEbkEUuSyGs}_;HzkWs3#pk_ zph}b4ARBp~%~+j6CE~Ba0=9ETu_6Q4KRVRL8$YJ*IN57BUraqko1cDT6aZyFFcW&- z%W-~rOC3eSaeH;lNSS<2z`dPhZ}k1Mm(qsiz3@b?46V{G?{O13rdU)=jIy~P9y?av z;WjBdyOK2TA!7YbhNR&}ueXJ^9O{YxC zH949iw{Wryv{tE#h=`-}o7DFS4(vCTxbwZ*ITpdpH%kPzL#ozpH$--8?kWQpj61eF z_BnkKLl)U#t49_RVt{AEl*|hXVQb*w3N#~DJ=Khx$g&bh%kb@S*5T!egh4mHdO=>f zfux8mm1A0fb<^cMtz0Z^>Ah$0a=%ica{c#UgHV16hPstS`OIuK7lVF9F8#N=Fi+ml z1i%gzC)0O%vDvkj@8R5&9edrdTqv$vjAKdc;E6Fu+P!w%yeF8JKNtj%rqB)zJP(kO z9lR1C-^R7ci4tIN1}4NPP1HWV7XlGvC(`r7*u|!1)+4E9@a? zbT||~GD8>Pnj=7pX)336Yucq*e_4l6FgVTL?0vpJ+uXkrz<+0F)HRL7QYKkSGf?48 z#PHNG&)0*9vp`Jxx(V1D&|L%nK+;V2Fd7ISbGFJEwIox`e;6eBℜw6i7m+es<*b4UmTg=;lLxml_J{M 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

@Q~v*Wkx9`>))00($+* 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 a3krY1#LqL{k3L+&{V6M`%a=Yj3HpEM0kpsX literal 0 HcmV?d00001 From bcf88fc2b3795b19cb99ac565964a088f86c5faa Mon Sep 17 00:00:00 2001 From: James Douglass Date: Wed, 23 Oct 2024 13:06:05 -0700 Subject: [PATCH 26/90] Update doc/api-docs/scripting.rst Co-authored-by: Emily Soth <43770515+emlys@users.noreply.github.com> --- doc/api-docs/scripting.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/api-docs/scripting.rst b/doc/api-docs/scripting.rst index b7c153d6e9..0669c9f28f 100644 --- a/doc/api-docs/scripting.rst +++ b/doc/api-docs/scripting.rst @@ -226,7 +226,7 @@ Example: Saving model log messages to a file When you save a model run to a python script, InVEST will automatically include code to write all logging to your console while it executes. But sometimes, -it's useful to save log messages from th emodel to a file. This can be done by +it's useful to save log messages from the model to a file. This can be done by adding a few lines of code to the script, just after the existing logging code: From 0287cb7e24e9feaed554b513c032f6bea3dbf4df Mon Sep 17 00:00:00 2001 From: James Douglass Date: Wed, 23 Oct 2024 13:09:25 -0700 Subject: [PATCH 27/90] Improving section title per @emlys 's suggestion. RE:#1660 --- doc/api-docs/conf.py | 2 +- doc/api-docs/scripting.rst | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/doc/api-docs/conf.py b/doc/api-docs/conf.py index 52205cf614..46b1e83993 100644 --- a/doc/api-docs/conf.py +++ b/doc/api-docs/conf.py @@ -187,7 +187,7 @@ natcap.invest.carbon.execute(args) For examples of scripting a model run, or multiple successive model runs, -see :ref:`CreatingSamplePythonScripts`. +see :ref:`CreatingPythonScripts`. .. contents:: Available Models and Tools: diff --git a/doc/api-docs/scripting.rst b/doc/api-docs/scripting.rst index 0669c9f28f..442a63375a 100644 --- a/doc/api-docs/scripting.rst +++ b/doc/api-docs/scripting.rst @@ -33,11 +33,11 @@ Alternate installation methods are available. Please see the :ref:`installing` guide for further instructions on setting up your python environment and installing the ``natcap.invest`` package. -.. _CreatingSamplePythonScripts: +.. _CreatingPythonScripts: -============================== -Creating Sample Python Scripts -============================== +======================= +Creating Python Scripts +======================= 1. **Launch InVEST Workbench and Open the Selected Model** @@ -53,7 +53,7 @@ Creating Sample Python Scripts several InVEST model runs in sequence, it would be reasonable to populate the user interface with data for the first run in the sequence. -3. **Generate a sample Python Script from the User Interface** +3. **Generate a Python Script from the User Interface** In the model interface, select *"Save as..."* in the left-hand menu bar, *"Python script"* in the dialog box, and then save the file to a known location. From c6ba4ccf95d6c286c1ff0d7d8c875bf3e0553b1d Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Wed, 23 Oct 2024 15:01:01 -0600 Subject: [PATCH 28/90] Update sample data revision hash --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index f225958acd..97af79b9f5 100644 --- a/Makefile +++ b/Makefile @@ -2,7 +2,7 @@ DATA_DIR := data GIT_SAMPLE_DATA_REPO := https://bitbucket.org/natcap/invest-sample-data.git GIT_SAMPLE_DATA_REPO_PATH := $(DATA_DIR)/invest-sample-data -GIT_SAMPLE_DATA_REPO_REV := ab8c74a62a93fd0019de2bca064abc0a5a07afab +GIT_SAMPLE_DATA_REPO_REV := 0f8b41557753dad3670ba8220f41650b51435a93 GIT_TEST_DATA_REPO := https://bitbucket.org/natcap/invest-test-data.git GIT_TEST_DATA_REPO_PATH := $(DATA_DIR)/invest-test-data From 4441d59ad27bbcba4ca7a9cf56d0a505d252bc75 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Wed, 23 Oct 2024 18:00:42 -0600 Subject: [PATCH 29/90] Update validation.py to avoid SyntaxError --- src/natcap/invest/validation.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/natcap/invest/validation.py b/src/natcap/invest/validation.py index c9c64cf085..34bcac6d85 100644 --- a/src/natcap/invest/validation.py +++ b/src/natcap/invest/validation.py @@ -642,7 +642,7 @@ def get_validated_dataframe( patterns.append(f'{groups[0]}(.+){groups[2]}') else: # for regular column names, use the exact name as the pattern - patterns.append(column.replace('(', '\(').replace(')', '\)')) + patterns.append(column.replace('(', '\\(').replace(')', '\\)')) # select only the columns that match a pattern df = df[[col for col in df.columns if any( From db395d3b17a62179caf34528ae92cef5335285ab Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Thu, 24 Oct 2024 13:31:55 -0600 Subject: [PATCH 30/90] Update with Python raw string notation --- src/natcap/invest/validation.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/natcap/invest/validation.py b/src/natcap/invest/validation.py index 34bcac6d85..d6f7df05fc 100644 --- a/src/natcap/invest/validation.py +++ b/src/natcap/invest/validation.py @@ -642,7 +642,7 @@ def get_validated_dataframe( patterns.append(f'{groups[0]}(.+){groups[2]}') else: # for regular column names, use the exact name as the pattern - patterns.append(column.replace('(', '\\(').replace(')', '\\)')) + patterns.append(column.replace('(', r'\(').replace(')', r'\)')) # select only the columns that match a pattern df = df[[col for col in df.columns if any( From d503097b7d980b3311418de4ae7e529f326dccec Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Fri, 1 Nov 2024 16:46:17 -0600 Subject: [PATCH 31/90] Get & store invest version to let workbench identify first run of a new version --- workbench/package.json | 2 +- workbench/src/main/ipcMainChannels.js | 1 + workbench/src/main/main.js | 2 + workbench/src/main/setupIsNewVersion.js | 54 +++++++++++++++++++++++++ workbench/src/renderer/app.jsx | 7 +++- workbench/src/renderer/index.jsx | 3 ++ 6 files changed, 67 insertions(+), 2 deletions(-) create mode 100644 workbench/src/main/setupIsNewVersion.js diff --git a/workbench/package.json b/workbench/package.json index c89365511a..e7c2ccaf4f 100644 --- a/workbench/package.json +++ b/workbench/package.json @@ -1,6 +1,6 @@ { "name": "invest-workbench", - "version": "0.1.0", + "version": "3.14.2", "description": "Models that map and value the goods and services from nature that sustain and fulfill human life", "main": "build/main/main.js", "homepage": "./", diff --git a/workbench/src/main/ipcMainChannels.js b/workbench/src/main/ipcMainChannels.js index f908d7c33b..7de3d7abe3 100644 --- a/workbench/src/main/ipcMainChannels.js +++ b/workbench/src/main/ipcMainChannels.js @@ -12,6 +12,7 @@ export const ipcMainChannels = { INVEST_RUN: 'invest-run', INVEST_VERSION: 'invest-version', IS_FIRST_RUN: 'is-first-run', + IS_NEW_VERSION: 'is-new-version', LOGGER: 'logger', OPEN_EXTERNAL_URL: 'open-external-url', OPEN_PATH: 'open-path', diff --git a/workbench/src/main/main.js b/workbench/src/main/main.js index 5b5b78f90f..fb3654c0d4 100644 --- a/workbench/src/main/main.js +++ b/workbench/src/main/main.js @@ -38,6 +38,7 @@ import BASE_URL from './baseUrl'; import { getLogger } from './logger'; import i18n from './i18n/i18n'; import pkg from '../../package.json'; +import { setupIsNewVersion } from './setupIsNewVersion'; const logger = getLogger(__filename.split('/').slice(-1)[0]); @@ -87,6 +88,7 @@ export const createWindow = async () => { setupDialogs(); setupCheckFilePermissions(); setupCheckFirstRun(); + setupIsNewVersion(); setupCheckStorageToken(); setupSettingsHandlers(); setupGetElectronPaths(); diff --git a/workbench/src/main/setupIsNewVersion.js b/workbench/src/main/setupIsNewVersion.js new file mode 100644 index 0000000000..dbedf9bd3f --- /dev/null +++ b/workbench/src/main/setupIsNewVersion.js @@ -0,0 +1,54 @@ +import fs from 'fs'; +import path from 'path'; + +import { + app, + ipcMain, +} from 'electron'; + +import { ipcMainChannels } from './ipcMainChannels'; +import { getLogger } from './logger'; +import pkg from '../../package.json'; + +const logger = getLogger(__filename.split('/').slice(-1)[0]); + +export const APP_VERSION_TOKEN = 'app-version-token.txt'; + +/** Determine whether this is the first run of the current running version. + * + * @returns {boolean} true if this version has not run before, otherwise false + */ +export async function isNewVersion() { + // Getting version from package.json is simplest because there is no need to + // spawn an invest process simply to get the version of the installed binary. + + // In production, pkg.version is overwritten by electron-builder-config.js. + // In dev, pkg.version is NOT overwritten. For consistency in dev mode, + // we should keep package.json in sync with the invest version, + // which _should_ be straightforward with this GHA: + // https://github.com/marketplace/actions/update-local-package-json-version-from-release-tag. + const investVersion = pkg.version; + const userDataPath = app.getPath('userData'); + const tokenPath = path.join(userDataPath, APP_VERSION_TOKEN); + try { + if (fs.existsSync(tokenPath)) { + const tokenContents = fs.readFileSync(tokenPath, {encoding: 'utf8'}); + if (tokenContents === investVersion) { + return false; + } + // If mismatch, overwrite with current version + fs.writeFileSync(tokenPath, investVersion); + } + // If file does not exist, create it + fs.writeFileSync(tokenPath, investVersion); + } catch (error) { + logger.warn(`Unable to write app-version token: ${error}`); + } + return true; +} + +export function setupIsNewVersion() { + ipcMain.handle( + ipcMainChannels.IS_NEW_VERSION, () => isNewVersion() + ); +} diff --git a/workbench/src/renderer/app.jsx b/workbench/src/renderer/app.jsx index e9c5872f98..cf1c8cca76 100644 --- a/workbench/src/renderer/app.jsx +++ b/workbench/src/renderer/app.jsx @@ -41,6 +41,7 @@ export default class App extends React.Component { investList: null, recentJobs: [], showDownloadModal: false, + isNewVersion: false, downloadedNofN: null, }; this.switchTabs = this.switchTabs.bind(this); @@ -65,6 +66,7 @@ export default class App extends React.Component { .includes(job.modelRunName) )), showDownloadModal: this.props.isFirstRun, + isNewVersion: this.props.isNewVersion, }); await i18n.changeLanguage(window.Workbench.LANGUAGE); ipcRenderer.on('download-status', (downloadedNofN) => { @@ -183,6 +185,7 @@ export default class App extends React.Component { openTabIDs, activeTab, showDownloadModal, + isNewVersion, downloadedNofN, } = this.state; @@ -291,7 +294,7 @@ export default class App extends React.Component { eventKey="home" > - InVEST + InVEST {isNewVersion && ' (new version!)'} @@ -357,6 +360,7 @@ export default class App extends React.Component { App.propTypes = { isFirstRun: PropTypes.bool, + isNewVersion: PropTypes.bool, nCPU: PropTypes.number, }; @@ -364,5 +368,6 @@ App.propTypes = { // can be undefined for unrelated tests. App.defaultProps = { isFirstRun: false, + isNewVersion: false, nCPU: 1, }; diff --git a/workbench/src/renderer/index.jsx b/workbench/src/renderer/index.jsx index 9cf222ea3a..b1277bfdb7 100644 --- a/workbench/src/renderer/index.jsx +++ b/workbench/src/renderer/index.jsx @@ -9,6 +9,8 @@ import { ipcMainChannels } from '../main/ipcMainChannels'; const { ipcRenderer } = window.Workbench.electron; const isFirstRun = await ipcRenderer.invoke(ipcMainChannels.IS_FIRST_RUN); +const isNewVersion = await ipcRenderer.invoke(ipcMainChannels.IS_NEW_VERSION); +console.log({isNewVersion}); const nCPU = await ipcRenderer.invoke(ipcMainChannels.GET_N_CPUS); const root = createRoot(document.getElementById('App')); @@ -16,6 +18,7 @@ root.render( From c550879348187dbb657fa1196735ed0e0d3c986b Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Fri, 1 Nov 2024 18:16:11 -0600 Subject: [PATCH 32/90] Add changelog modal with placeholder content --- workbench/src/renderer/app.jsx | 23 +++++--- .../renderer/components/Changelog/index.jsx | 53 +++++++++++++++++++ 2 files changed, 70 insertions(+), 6 deletions(-) create mode 100644 workbench/src/renderer/components/Changelog/index.jsx diff --git a/workbench/src/renderer/app.jsx b/workbench/src/renderer/app.jsx index cf1c8cca76..b5c845ab7e 100644 --- a/workbench/src/renderer/app.jsx +++ b/workbench/src/renderer/app.jsx @@ -24,6 +24,7 @@ import DownloadProgressBar from './components/DownloadProgressBar'; import { getInvestModelNames } from './server_requests'; import InvestJob from './InvestJob'; import { dragOverHandlerNone } from './utils'; +import Changelog from './components/Changelog'; const { ipcRenderer } = window.Workbench.electron; @@ -41,7 +42,7 @@ export default class App extends React.Component { investList: null, recentJobs: [], showDownloadModal: false, - isNewVersion: false, + showChangelog: false, downloadedNofN: null, }; this.switchTabs = this.switchTabs.bind(this); @@ -66,7 +67,7 @@ export default class App extends React.Component { .includes(job.modelRunName) )), showDownloadModal: this.props.isFirstRun, - isNewVersion: this.props.isNewVersion, + showChangelog: this.props.isNewVersion, }); await i18n.changeLanguage(window.Workbench.LANGUAGE); ipcRenderer.on('download-status', (downloadedNofN) => { @@ -96,6 +97,12 @@ export default class App extends React.Component { }); } + closeChangelogModal() { + this.setState({ + showChangelog: false, + }); + } + /** Push data for a new InvestTab component to an array. * * @param {InvestJob} job - as constructed by new InvestJob() @@ -185,7 +192,7 @@ export default class App extends React.Component { openTabIDs, activeTab, showDownloadModal, - isNewVersion, + showChangelog, downloadedNofN, } = this.state; @@ -280,6 +287,10 @@ export default class App extends React.Component { show={showDownloadModal} closeModal={() => this.showDownloadModal(false)} /> + this.closeChangelogModal()} + /> - InVEST {isNewVersion && ' (new version!)'} + InVEST @@ -360,7 +371,7 @@ export default class App extends React.Component { App.propTypes = { isFirstRun: PropTypes.bool, - isNewVersion: PropTypes.bool, + showChangelog: PropTypes.bool, nCPU: PropTypes.number, }; @@ -368,6 +379,6 @@ App.propTypes = { // can be undefined for unrelated tests. App.defaultProps = { isFirstRun: false, - isNewVersion: false, + showChangelog: false, nCPU: 1, }; diff --git a/workbench/src/renderer/components/Changelog/index.jsx b/workbench/src/renderer/components/Changelog/index.jsx new file mode 100644 index 0000000000..ef41c5843e --- /dev/null +++ b/workbench/src/renderer/components/Changelog/index.jsx @@ -0,0 +1,53 @@ +import PropTypes from 'prop-types'; +import Button from 'react-bootstrap/Button'; +import Modal from 'react-bootstrap/Modal'; +import { MdClose } from 'react-icons/md'; +import { useTranslation } from 'react-i18next'; + +export default function Changelog(props) { + const { t } = useTranslation(); + return ( + + + {t('New in this version')} + + + +

+ + + ) +} + +Changelog.propTypes = { + show: PropTypes.bool.isRequired, + close: PropTypes.func.isRequired, +}; From 4f2149b05e76486db7a1c440b7b084837b994019 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Tue, 5 Nov 2024 12:25:53 -0700 Subject: [PATCH 33/90] Load HTML from external file and render just the relevant section --- .../renderer/components/Changelog/index.jsx | 63 ++++++++++++------- workbench/src/renderer/styles/style.css | 17 ++++- 2 files changed, 57 insertions(+), 23 deletions(-) diff --git a/workbench/src/renderer/components/Changelog/index.jsx b/workbench/src/renderer/components/Changelog/index.jsx index ef41c5843e..4a67af7a90 100644 --- a/workbench/src/renderer/components/Changelog/index.jsx +++ b/workbench/src/renderer/components/Changelog/index.jsx @@ -1,15 +1,48 @@ +import { useEffect, useState } from 'react'; import PropTypes from 'prop-types'; import Button from 'react-bootstrap/Button'; import Modal from 'react-bootstrap/Modal'; import { MdClose } from 'react-icons/md'; import { useTranslation } from 'react-i18next'; +import pkg from '../../../../package.json'; + export default function Changelog(props) { const { t } = useTranslation(); + const [htmlContent, setHtmlContent] = useState(''); + + // Load HTML from external file (which is generated by Python build process). + useEffect(() => { + fetch('changelog.html') + .then(response => response.text()) + .then(htmlString => { + // Find the section whose heading explicitly matches the current version. + const versionStr = pkg.version; + const escapedVersionStr = versionStr.split('.').join('\\.'); + const sectionRegex = new RegExp( + `[\\s]*?

${escapedVersionStr}\\b[\\s\\S]*?

[\\s\\S]*?` + ); + const sectionMatches = htmlString.match(sectionRegex); + if (sectionMatches && sectionMatches.length) { + let latestVersionSection = sectionMatches[0]; + const linkRegex = / {t('New in this version')} @@ -22,29 +55,15 @@ export default function Changelog(props) { - -
    -
  • - General -
      -
    • Updated something
    • -
    • Updated something else
    • -
    -
  • -
  • - Workbench -
      -
    • Added a feature
    • -
    • Fixed a bug
    • -
    -
  • -
  • - Etc. -
  • -
+ {/* Setting inner HTML in this way is OK because + the HTML content is controlled by our build process + and not, for example, sourced from user input. */} + - ) + ); } Changelog.propTypes = { diff --git a/workbench/src/renderer/styles/style.css b/workbench/src/renderer/styles/style.css index a335cabd6f..2068b75921 100644 --- a/workbench/src/renderer/styles/style.css +++ b/workbench/src/renderer/styles/style.css @@ -253,7 +253,7 @@ exceed 100% of window.*/ } .recent-job-card { - width: inherit; + width: inherit; margin-bottom: 1rem; padding: 0; height: fit-content; @@ -617,3 +617,18 @@ input[type=text]::placeholder { .error-boundary .btn { margin: 1rem; } + +/* Changelog modal */ +.link-external { + &:after { + content: ''; + display: inline-block; + width: 1rem; + height: 1rem; + /* Icon is react-icons/md/MdOpenInNew, as a URL-encoded SVG */ + background-image: url("data:image/svg+xml,%3Csvg stroke='currentColor' fill='currentColor' stroke-width='0' viewBox='0 0 24 24' class='mr-1' height='1em' width='1em' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='none' d='M0 0h24v24H0z'%3E%3C/path%3E%3Cpath d='M19 19H5V5h7V3H5a2 2 0 00-2 2v14a2 2 0 002 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z'%3E%3C/path%3E%3C/svg%3E"); + background-repeat: no-repeat; + background-position: left 0.125rem top 0.125rem; + background-size: 1rem 1rem; + } +} From 4b8a70d3712645e0f1169d41d72ccf0c1c6e498f Mon Sep 17 00:00:00 2001 From: James Douglass Date: Tue, 5 Nov 2024 15:19:04 -0600 Subject: [PATCH 34/90] Also handling sanitized package names. RE:#1679 --- .github/workflows/release-part-2.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/release-part-2.yml b/.github/workflows/release-part-2.yml index 7e4e119c8c..969ab19b3a 100644 --- a/.github/workflows/release-part-2.yml +++ b/.github/workflows/release-part-2.yml @@ -99,7 +99,7 @@ jobs: twine upload \ --username="__token__" \ --password=${{ secrets.PYPI_NATCAP_INVEST_TOKEN }} \ - artifacts/natcap.invest* + artifacts/natcap.invest* artifacts/natcap_invest* - name: Roll back on failure if: failure() From f63d0587ff3ca2db61ad70ed1a8f52a176830aad Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Tue, 5 Nov 2024 16:07:45 -0700 Subject: [PATCH 35/90] Add changelog target to Makefile --- Makefile | 7 +++++++ requirements-dev.txt | 1 + 2 files changed, 8 insertions(+) diff --git a/Makefile b/Makefile index 97af79b9f5..a75c58f220 100644 --- a/Makefile +++ b/Makefile @@ -66,6 +66,7 @@ PYTHON_ARCH := $(shell $(PYTHON) -c "import sys; print('x86' if sys.maxsize <= 2 GSUTIL := gsutil SIGNTOOL := SignTool +RST2HTML5 := rst2html5 # local directory names DIST_DIR := dist @@ -73,6 +74,8 @@ DIST_DATA_DIR := $(DIST_DIR)/data BUILD_DIR := build WORKBENCH := workbench WORKBENCH_DIST_DIR := $(WORKBENCH)/dist +CHANGELOG_SRC := HISTORY.rst +CHANGELOG_DEST := $(WORKBENCH)/changelog.html # The fork name and user here are derived from the git path on github. # The fork name will need to be set manually (e.g. make FORKNAME=natcap/invest) @@ -141,6 +144,7 @@ help: @echo " binaries to build pyinstaller binaries" @echo " apidocs to build HTML API documentation" @echo " userguide to build HTML version of the users guide" + @echo " changelog to build HTML version of the changelog" @echo " python_packages to build natcap.invest wheel and source distributions" @echo " codesign_mac to sign the mac disk image using the codesign utility" @echo " codesign_windows to sign the windows installer using the SignTool utility" @@ -366,6 +370,9 @@ deploy: @echo "Application binaries (if they were created) can be downloaded from:" @echo " * $(DOWNLOAD_DIR_URL)" +changelog: + $(RST2HTML5) $(CHANGELOG_SRC) $(CHANGELOG_DEST) + # Notes on Makefile development # # * Use the -drR to show the decision tree (and none of the implicit rules) diff --git a/requirements-dev.txt b/requirements-dev.txt index 6325f1f62d..75b210cc1b 100644 --- a/requirements-dev.txt +++ b/requirements-dev.txt @@ -26,3 +26,4 @@ requests coverage xlwt build # pip-only +rst2html5 From d5da9d16b7531762a181d9a5eede775d1c0411c5 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Tue, 5 Nov 2024 16:18:13 -0700 Subject: [PATCH 36/90] Add RST to HTML conversion to release workflow --- .github/workflows/release-part-1.yml | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/.github/workflows/release-part-1.yml b/.github/workflows/release-part-1.yml index 4b6351e85f..42c9994fdf 100644 --- a/.github/workflows/release-part-1.yml +++ b/.github/workflows/release-part-1.yml @@ -32,6 +32,9 @@ jobs: - name: Create autorelease branch run: git checkout -b "$AUTORELEASE_BRANCH" + - name: Install dependencies + run: pip install rst2html5 + # Replace # # Unreleased Changes @@ -45,7 +48,7 @@ jobs: # # X.X.X (XXXX-XX-XX) # ------------------ - - name: Update HISTORY.rst + - name: Update HISTORY.rst and changelog.html run: | HEADER="$VERSION ($(date '+%Y-%m-%d'))" HEADER_LENGTH=${#HEADER} @@ -53,7 +56,9 @@ jobs: perl -0777 -i -pe \ "s/Unreleased Changes\n------------------/..\n Unreleased Changes\n ------------------\n\n${HEADER}\n${UNDERLINE}/g" \ HISTORY.rst + rst2html5 HISTORY.rst workbench/changelog.html git add HISTORY.rst + git add workbench/changelog.html git commit -m "Committing the $VERSION release." - name: Tag and push From 5918705616446cc4773b81dc08bea8c2b37b7404 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Tue, 5 Nov 2024 18:20:17 -0700 Subject: [PATCH 37/90] Add package.json version update steps to release workflow --- .github/workflows/release-part-1.yml | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/.github/workflows/release-part-1.yml b/.github/workflows/release-part-1.yml index 42c9994fdf..226797a4d7 100644 --- a/.github/workflows/release-part-1.yml +++ b/.github/workflows/release-part-1.yml @@ -61,6 +61,17 @@ jobs: git add workbench/changelog.html git commit -m "Committing the $VERSION release." + - name: Update package.json version + uses: BellCubeDev/update-package-version-by-release-tag@v2 + with: + version: ${{ inputs.version }} + package-json-path: "workbench/package.json" + + - name: Commit updated package.json + run: | + git add workbench/package.json + git commit -m "Update package.json version to $VERSION" + - name: Tag and push run: | git tag $VERSION From ffb04563c16b4fcc50546ef4f72d8a4a3f323a0c Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Tue, 5 Nov 2024 18:20:42 -0700 Subject: [PATCH 38/90] Remove console.log & unneeded comments --- workbench/src/main/setupIsNewVersion.js | 6 ------ workbench/src/renderer/index.jsx | 1 - 2 files changed, 7 deletions(-) diff --git a/workbench/src/main/setupIsNewVersion.js b/workbench/src/main/setupIsNewVersion.js index dbedf9bd3f..0e338995cc 100644 --- a/workbench/src/main/setupIsNewVersion.js +++ b/workbench/src/main/setupIsNewVersion.js @@ -21,12 +21,6 @@ export const APP_VERSION_TOKEN = 'app-version-token.txt'; export async function isNewVersion() { // Getting version from package.json is simplest because there is no need to // spawn an invest process simply to get the version of the installed binary. - - // In production, pkg.version is overwritten by electron-builder-config.js. - // In dev, pkg.version is NOT overwritten. For consistency in dev mode, - // we should keep package.json in sync with the invest version, - // which _should_ be straightforward with this GHA: - // https://github.com/marketplace/actions/update-local-package-json-version-from-release-tag. const investVersion = pkg.version; const userDataPath = app.getPath('userData'); const tokenPath = path.join(userDataPath, APP_VERSION_TOKEN); diff --git a/workbench/src/renderer/index.jsx b/workbench/src/renderer/index.jsx index b1277bfdb7..1cb962314b 100644 --- a/workbench/src/renderer/index.jsx +++ b/workbench/src/renderer/index.jsx @@ -10,7 +10,6 @@ const { ipcRenderer } = window.Workbench.electron; const isFirstRun = await ipcRenderer.invoke(ipcMainChannels.IS_FIRST_RUN); const isNewVersion = await ipcRenderer.invoke(ipcMainChannels.IS_NEW_VERSION); -console.log({isNewVersion}); const nCPU = await ipcRenderer.invoke(ipcMainChannels.GET_N_CPUS); const root = createRoot(document.getElementById('App')); From 65f3bb90616adebfe0d8002316643ad0e1b4fb7d Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Tue, 5 Nov 2024 18:31:11 -0700 Subject: [PATCH 39/90] Rearrange release workflow steps to consolidate release-related changes into a single commit --- .github/workflows/release-part-1.yml | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/.github/workflows/release-part-1.yml b/.github/workflows/release-part-1.yml index 226797a4d7..e60ca9cd73 100644 --- a/.github/workflows/release-part-1.yml +++ b/.github/workflows/release-part-1.yml @@ -32,9 +32,6 @@ jobs: - name: Create autorelease branch run: git checkout -b "$AUTORELEASE_BRANCH" - - name: Install dependencies - run: pip install rst2html5 - # Replace # # Unreleased Changes @@ -48,7 +45,7 @@ jobs: # # X.X.X (XXXX-XX-XX) # ------------------ - - name: Update HISTORY.rst and changelog.html + - name: Update HISTORY.rst run: | HEADER="$VERSION ($(date '+%Y-%m-%d'))" HEADER_LENGTH=${#HEADER} @@ -56,21 +53,25 @@ jobs: perl -0777 -i -pe \ "s/Unreleased Changes\n------------------/..\n Unreleased Changes\n ------------------\n\n${HEADER}\n${UNDERLINE}/g" \ HISTORY.rst - rst2html5 HISTORY.rst workbench/changelog.html - git add HISTORY.rst - git add workbench/changelog.html - git commit -m "Committing the $VERSION release." + + - name: Install dependencies + run: pip install rst2html5 + + - name: Generate changelog.html + run: rst2html5 HISTORY.rst workbench/changelog.html - name: Update package.json version uses: BellCubeDev/update-package-version-by-release-tag@v2 with: version: ${{ inputs.version }} - package-json-path: "workbench/package.json" + package-json-path: workbench/package.json - - name: Commit updated package.json + - name: Commit updated HISTORY.rst, changelog.html, and package.json run: | + git add HISTORY.rst + git add workbench/changelog.html git add workbench/package.json - git commit -m "Update package.json version to $VERSION" + git commit -m "Committing the $VERSION release." - name: Tag and push run: | From 5701a6ba703436d4fd43e96bd2e52094cc83fb49 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Wed, 6 Nov 2024 18:32:21 -0700 Subject: [PATCH 40/90] Set up dynamic changelog URL --- workbench/src/main/ipcMainChannels.js | 1 + workbench/src/main/main.js | 2 + workbench/src/main/setupBaseUrl.js | 13 +++++ .../renderer/components/Changelog/index.jsx | 53 +++++++++++-------- workbench/tests/main/main.test.js | 2 + workbench/vite.config.js | 1 + 6 files changed, 49 insertions(+), 23 deletions(-) create mode 100644 workbench/src/main/setupBaseUrl.js diff --git a/workbench/src/main/ipcMainChannels.js b/workbench/src/main/ipcMainChannels.js index 7de3d7abe3..98ad85112d 100644 --- a/workbench/src/main/ipcMainChannels.js +++ b/workbench/src/main/ipcMainChannels.js @@ -1,4 +1,5 @@ export const ipcMainChannels = { + BASE_URL: 'base-url', CHANGE_LANGUAGE: 'change-language', CHECK_FILE_PERMISSIONS: 'check-file-permissions', CHECK_STORAGE_TOKEN: 'check-storage-token', diff --git a/workbench/src/main/main.js b/workbench/src/main/main.js index fb3654c0d4..a71b9fa51e 100644 --- a/workbench/src/main/main.js +++ b/workbench/src/main/main.js @@ -39,6 +39,7 @@ import { getLogger } from './logger'; import i18n from './i18n/i18n'; import pkg from '../../package.json'; import { setupIsNewVersion } from './setupIsNewVersion'; +import { setupBaseUrl } from './setupBaseUrl'; const logger = getLogger(__filename.split('/').slice(-1)[0]); @@ -96,6 +97,7 @@ export const createWindow = async () => { setupInvestLogReaderHandler(); setupOpenExternalUrl(); setupRendererLogger(); + setupBaseUrl(); await getFlaskIsReady(); const devModeArg = ELECTRON_DEV_MODE ? '--devmode' : ''; diff --git a/workbench/src/main/setupBaseUrl.js b/workbench/src/main/setupBaseUrl.js new file mode 100644 index 0000000000..973e1035f4 --- /dev/null +++ b/workbench/src/main/setupBaseUrl.js @@ -0,0 +1,13 @@ +import { + ipcMain, +} from 'electron'; + +import { ipcMainChannels } from './ipcMainChannels'; + +import baseUrl from './baseUrl'; + +export function setupBaseUrl() { + ipcMain.handle( + ipcMainChannels.BASE_URL, () => baseUrl + ); +} diff --git a/workbench/src/renderer/components/Changelog/index.jsx b/workbench/src/renderer/components/Changelog/index.jsx index 4a67af7a90..d49bdf688c 100644 --- a/workbench/src/renderer/components/Changelog/index.jsx +++ b/workbench/src/renderer/components/Changelog/index.jsx @@ -1,4 +1,4 @@ -import { useEffect, useState } from 'react'; +import React, { useEffect, useState } from 'react'; import PropTypes from 'prop-types'; import Button from 'react-bootstrap/Button'; import Modal from 'react-bootstrap/Modal'; @@ -6,6 +6,9 @@ import { MdClose } from 'react-icons/md'; import { useTranslation } from 'react-i18next'; import pkg from '../../../../package.json'; +import { ipcMainChannels } from '../../../main/ipcMainChannels'; + +const { ipcRenderer } = window.Workbench.electron; export default function Changelog(props) { const { t } = useTranslation(); @@ -13,29 +16,33 @@ export default function Changelog(props) { // Load HTML from external file (which is generated by Python build process). useEffect(() => { - fetch('changelog.html') - .then(response => response.text()) - .then(htmlString => { - // Find the section whose heading explicitly matches the current version. - const versionStr = pkg.version; - const escapedVersionStr = versionStr.split('.').join('\\.'); - const sectionRegex = new RegExp( - `[\\s]*?

${escapedVersionStr}\\b[\\s\\S]*?

[\\s\\S]*?` - ); - const sectionMatches = htmlString.match(sectionRegex); - if (sectionMatches && sectionMatches.length) { - let latestVersionSection = sectionMatches[0]; - const linkRegex = / response.text()) + .then(htmlString => { + // Find the section whose heading explicitly matches the current version. + const versionStr = pkg.version; + const escapedVersionStr = versionStr.split('.').join('\\.'); + const sectionRegex = new RegExp( + `[\\s]*?

${escapedVersionStr}\\b[\\s\\S]*?

[\\s\\S]*?` ); - setHtmlContent({ - __html: latestVersionSection - }); - } - }); + const sectionMatches = htmlString.match(sectionRegex); + if (sectionMatches && sectionMatches.length) { + let latestVersionSection = sectionMatches[0]; + const linkRegex = / { test('should register various ipcMain listeners', async () => { await createWindow(); const expectedHandleChannels = [ + ipcMainChannels.BASE_URL, ipcMainChannels.CHANGE_LANGUAGE, ipcMainChannels.CHECK_STORAGE_TOKEN, ipcMainChannels.CHECK_FILE_PERMISSIONS, ipcMainChannels.GET_SETTING, ipcMainChannels.GET_N_CPUS, ipcMainChannels.INVEST_VERSION, + ipcMainChannels.IS_NEW_VERSION, ipcMainChannels.IS_FIRST_RUN, ipcMainChannels.OPEN_PATH, ipcMainChannels.SHOW_OPEN_DIALOG, diff --git a/workbench/vite.config.js b/workbench/vite.config.js index a8c1d4f045..ae4e607992 100644 --- a/workbench/vite.config.js +++ b/workbench/vite.config.js @@ -24,6 +24,7 @@ export default defineConfig({ path.resolve(PROJECT_ROOT, 'splash.html'), path.resolve(PROJECT_ROOT, 'report_a_problem.html'), path.resolve(PROJECT_ROOT, 'about.html'), + path.resolve(PROJECT_ROOT, 'changelog.html'), ], }, emptyOutDir: true, From dedd45c493fecebc318c1602a07c9b977f0dbcbd Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Thu, 7 Nov 2024 12:40:39 -0700 Subject: [PATCH 41/90] Update version token to support multiple installed versions --- workbench/src/main/setupIsNewVersion.js | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/workbench/src/main/setupIsNewVersion.js b/workbench/src/main/setupIsNewVersion.js index 0e338995cc..14472e33e9 100644 --- a/workbench/src/main/setupIsNewVersion.js +++ b/workbench/src/main/setupIsNewVersion.js @@ -21,20 +21,24 @@ export const APP_VERSION_TOKEN = 'app-version-token.txt'; export async function isNewVersion() { // Getting version from package.json is simplest because there is no need to // spawn an invest process simply to get the version of the installed binary. - const investVersion = pkg.version; + const currentVersion = pkg.version; const userDataPath = app.getPath('userData'); const tokenPath = path.join(userDataPath, APP_VERSION_TOKEN); try { if (fs.existsSync(tokenPath)) { - const tokenContents = fs.readFileSync(tokenPath, {encoding: 'utf8'}); - if (tokenContents === investVersion) { - return false; + const tokenString = fs.readFileSync(tokenPath, {encoding: 'utf8'}); + if (tokenString) { + const installedVersionList = tokenString.split(','); + if (installedVersionList.includes(currentVersion)) { + return false; + } + // If current version not found, add it + fs.writeFileSync(tokenPath, `${tokenString},${currentVersion}`); + return true; } - // If mismatch, overwrite with current version - fs.writeFileSync(tokenPath, investVersion); } // If file does not exist, create it - fs.writeFileSync(tokenPath, investVersion); + fs.writeFileSync(tokenPath, currentVersion); } catch (error) { logger.warn(`Unable to write app-version token: ${error}`); } From 23b07d399e6f505b836f39210103fb4a2cb69399 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Thu, 7 Nov 2024 14:23:20 -0700 Subject: [PATCH 42/90] Delay showing changelog modal until after download modal closes (if first run) --- workbench/src/renderer/app.jsx | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/workbench/src/renderer/app.jsx b/workbench/src/renderer/app.jsx index b5c845ab7e..69472a2e6b 100644 --- a/workbench/src/renderer/app.jsx +++ b/workbench/src/renderer/app.jsx @@ -42,8 +42,9 @@ export default class App extends React.Component { investList: null, recentJobs: [], showDownloadModal: false, - showChangelog: false, downloadedNofN: null, + showChangelog: false, + changelogDismissed: false, }; this.switchTabs = this.switchTabs.bind(this); this.openInvestModel = this.openInvestModel.bind(this); @@ -67,7 +68,9 @@ export default class App extends React.Component { .includes(job.modelRunName) )), showDownloadModal: this.props.isFirstRun, - showChangelog: this.props.isNewVersion, + // Show changelog if this is a new version, + // but if it's the first run ever, wait until after download modal closes. + showChangelog: this.props.isNewVersion && !this.props.isFirstRun, }); await i18n.changeLanguage(window.Workbench.LANGUAGE); ipcRenderer.on('download-status', (downloadedNofN) => { @@ -95,11 +98,19 @@ export default class App extends React.Component { this.setState({ showDownloadModal: shouldShow, }); + // After close, show changelog if new version and app has just launched + // (i.e., show changelog only once, after the first time the download modal closes). + if (!shouldShow && this.props.isNewVersion && !this.state.changelogDismissed) { + this.setState({ + showChangelog: true, + }); + } } closeChangelogModal() { this.setState({ showChangelog: false, + changelogDismissed: true, }); } From c66b70c1abe8aa25fb555c5bba4f4ba5570c2bd7 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Thu, 7 Nov 2024 14:32:14 -0700 Subject: [PATCH 43/90] Fix test failures --- workbench/src/renderer/app.jsx | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/workbench/src/renderer/app.jsx b/workbench/src/renderer/app.jsx index 69472a2e6b..8cffa180b0 100644 --- a/workbench/src/renderer/app.jsx +++ b/workbench/src/renderer/app.jsx @@ -298,10 +298,13 @@ export default class App extends React.Component { show={showDownloadModal} closeModal={() => this.showDownloadModal(false)} /> - this.closeChangelogModal()} - /> + { + showChangelog && + this.closeChangelogModal()} + /> + } Date: Thu, 7 Nov 2024 15:09:12 -0700 Subject: [PATCH 44/90] Update HISTORY and commit changelog.html --- HISTORY.rst | 2 + workbench/changelog.html | 3233 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 3235 insertions(+) create mode 100644 workbench/changelog.html diff --git a/HISTORY.rst b/HISTORY.rst index 5eb71f8807..9081e6be3c 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -61,6 +61,8 @@ Unreleased Changes (https://github.com/natcap/invest/issues/1609). * Improved error handling when a datastack cannot be saved with relative paths across drives (https://github.com/natcap/invest/issues/1608). + * The InVEST changelog now displays in the Workbench the first time a new + version is launched (https://github.com/natcap/invest/issues/1368). * Coastal Vulnerability * Fixed a regression where an AOI with multiple features could raise a TypeError after intersecting with the landmass polygon. diff --git a/workbench/changelog.html b/workbench/changelog.html new file mode 100644 index 0000000000..7f2b62bb56 --- /dev/null +++ b/workbench/changelog.html @@ -0,0 +1,3233 @@ + + + + + + + + +
+

Unreleased Changes

+
+
+
+

3.14.2 (2024-05-29)

+
    +
  • +
    +
    General
    +
    +
      +
    • Validation now covers file paths contained in CSVs. CSV validation will fail if the files listed in a CSV fail to validate. https://github.com/natcap/invest/issues/327
    • +
    • We have updated validation in several ways that will improve the developer experience of working with InVEST models, and we hope will also improve the user experience: +
        +
      • Symbols in conditional requirement expressions now represent the values of parameters instead of whether the value of the parameter is sufficient. If a symbol is not present in args as a key, the symbol will have a value of False. This allows for value-based comparisons, which is useful in models that have overlapping modes of operation. https://github.com/natcap/invest/issues/1509
      • +
      • Vector fields, CSV rows/columns and the 1st level of directory contents may now all be conditionally required based on a python expression.
      • +
      • Under certain circumstances, validation may return more warnings than before. This specifically applies to model inputs that have conditional requirement expressions where their expression evaluates to False, and the user has provided a value for this parameter. Previous versions of InVEST would skip these parameters' type-specific validation. Now, these parameters will be validated with their type-specific validation checks.
      • +
      +
    • +
    • Add support for latest GDAL versions; remove test-specific constraint on GDAL versions from invest requirements. https://github.com/natcap/invest/issues/916
    • +
    • Updated to Cython 3 (https://github.com/natcap/invest/issues/556)
    • +
    +
    +
    +
  • +
  • +
    +
    Annual Water Yield
    +
    + +
    +
    +
  • +
  • +
    +
    Coastal Blue Carbon
    +
    +
      +
    • Updated model validation to prevent the case where a user provides only one snapshot year and no analysis year (#1534). Also enforces that the analysis year, if provided, is greater than the latest snapshot year. An analysis year equal to the latest snapshot year is no longer allowed.
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal Vulnerability
    +
    + +
    +
    +
  • +
  • +
    +
    HRA
    +
    +
      +
    • Fixed a bug where habitat and stressor vectors were not being rasterized with the ALL_TOUCHED=TRUE setting.
    • +
    +
    +
    +
  • +
  • +
    +
    Scenic Quality
    +
    +
      +
    • Fixed an issue with viewshed calculations where some slight numerical error was introduced on M1 Macs, but not on x86-based computers. This numerical error was leading to slightly different visibility results. https://github.com/natcap/invest/issues/1562
    • +
    +
    +
    +
  • +
  • +
    +
    SDR
    +
    +
      +
    • Fixed an issue encountered in the sediment deposition function where rasters with more than 2^32 pixels would raise a cryptic error relating to negative dimensions. https://github.com/natcap/invest/issues/1431
    • +
    • Optimized the creation of the summary vector by minimizing the number of times the target vector needs to be rasterized.
    • +
    +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    + +
    +
    +
  • +
  • +
    +
    Wind Energy
    +
    +
      +
    • Fixed a bug where some number inputs were not being properly cast to float or int types. If the inputs happened to be passed as a str this caused unintended side effects such as a concatenation error. (https://github.com/natcap/invest/issues/1498)
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Nature Access
    +
    +
      +
    • Fixed a NameError that occurred when running the model using search radii defined per population group with an exponential search kernel. https://github.com/natcap/invest/issues/1502
    • +
    • Fixed an issue where Urban Nature Access would crash if an administrative boundary geometry did not overlap any people in the population raster. https://github.com/natcap/invest/issues/1503
    • +
    • Fixed an issue where validation was failing to catch missing values in the uniform search radius args key when using uniform search radii. https://github.com/natcap/invest/issues/1509
    • +
    • Fixed an issue where the output administrative units vector's Pund_adm and Povr_adm fields representing undersupplied and oversupplied populations, respectively, had values of 0 when running the model with search radii defined per population group. The output administrative units vector now has the correct values for these fields, consistent with the user's guide chapter. https://github.com/natcap/invest/issues/1512
    • +
    • Fixed an issue where certain nodata values were not being handled correctly, leading to pixel values of +/- infinity in the urban nature balance output raster. https://github.com/natcap/invest/issues/1519
    • +
    • Fixed an issue where an LULC raster without a nodata value would always raise in exception during reclassification. https://github.com/natcap/invest/issues/1539
    • +
    +
    +
    +
  • +
+
+
+

3.14.1 (2023-12-18)

+
    +
  • +
    +
    General
    +
    +
      +
    • In advance of the numpy 2.0 release, function calls to numpy.product have been replaced with numpy.prod. https://github.com/natcap/invest/issues/1410
    • +
    • Add support for python 3.11 (#1103)
    • +
    • Adding a docker container that is built on each commit where a change to model code, requirements, or the docker configuration has been made. https://github.com/natcap/invest/issues/1115
    • +
    • Vector geometry types will now be validated for all models (#1374)
    • +
    • Datastack archives will now be correctly extracted (#1308)
    • +
    • Validation of tables has been improved and standardized, which should result in more readable validation errors. (#1379)
    • +
    • Updated to pygeoprocessing 2.4.2. This includes an update to pygeoprocessing.zonal_statistics, which is now more correct on certain edge cases. Aggregated model results may change slightly.
    • +
    • Removed the utils functions array_equals_nodata, exponential_decay_kernel_raster, and gaussian_decay_kernel_raster, which were obsoleted by new pygeoprocessing features.
    • +
    • Version metadata at import time is now fetched with importlib.metadata instead of pkg_resources. (#1442)
    • +
    • The API docs logo has been updated to use the latest version of the InVEST logo. (#1463)
    • +
    +
    +
    +
  • +
  • +
    +
    Workbench
    +
    + +
    +
    +
  • +
  • +
    +
    Coastal Vulnerability
    +
    + +
    +
    +
  • +
  • +
    +
    Habitat Quality
    +
    + +
    +
    +
  • +
  • +
    +
    HRA
    +
    + +
    +
    +
  • +
  • +
    +
    NDR
    +
    + +
    +
    +
  • +
  • +
    +
    Pollination
    +
    +
      +
    • Fixed a regression where nodata values were not being properly compared. This was only an issue in some development builds after 3.14.0. (#1458)
    • +
    • Replaced custom kernel implementation with pygeoprocessing.kernels. Convolution results may be slightly different (more accurate).
    • +
    +
    +
    +
  • +
  • +
    +
    SDR
    +
    +
      +
    • Fixed an issue with SDR's sediment deposition where large regions would become nodata in cases where the DEM has valid data but other inputs (LULC, erosivity, erodibility) did not have valid pixels. Now, all raster inputs are mutually masked so that only those pixel stacks continue through to the model where all pixels in the stack are non-nodata. (#911)
    • +
    • RKLS, USLE, avoided erosion, and avoided export rasters will now have nodata in streams (#1415)
    • +
    • Fixed an issue in SDR's sediment deposition where, on rasters with more than 2^31 pixels, the model would crash with an error relating to a negative (overflowed) index. https://github.com/natcap/invest/issues/1431
    • +
    +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    +
      +
    • Fixed an issue in Seasonal Water Yield's baseflow routing and local recharge functions where, on rasters with more than 2^31 pixels, the model would crash with an error relating to a negative (overflowed) index. https://github.com/natcap/invest/issues/1431
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Cooling
    +
    +
      +
    • Fixed a bug where model would error out if any feature in the buildings vector was missing a geometry; now they will be skipped (#1401)
    • +
    +
    +
    +
  • +
  • +
    +
    Wind Energy
    +
    +
      +
    • Fixed a bug where model would error when the grid points path was empty (#1417)
    • +
    +
    +
    +
  • +
+
+
+

3.14.0 (2023-09-08)

+
    +
  • +
    +
    General
    +
    +
      +
    • Fixed a bug in the CLI where invest getspec --json failed on non-json-serializable objects such as pint.Unit. https://github.com/natcap/invest/issues/1280
    • +
    • A new directory at ./doc/decision-records has been created for "Architecture/Any Decision Records", which will serve as a record of nontrivial decisions that were made to InVEST and why. This is intended for reference by our science and software teams, and also by the community at large when inquiring about a nontrivial change. https://github.com/natcap/invest/issues/1079
    • +
    • Updated the package installation instructions in the API docs for clarity and also to highlight the ease of installation through conda-forge. https://github.com/natcap/invest/issues/1256
    • +
    • utils.build_lookup_from_csv has been deprecated and its functionality has been merged into utils.read_csv_to_dataframe (#1319), (#1327)
    • +
    • Standardized on keeping the execute and validate functions orthogonal. Now no models call validate from execute. This affected AWY, CV, UFRM, Wave Energy, and Wind Energy. (#1373)
    • +
    • Improved the validation message that is returned when not all spatial inputs overlap (#502)
    • +
    • Standardized the name and location of the taskgraph cache directory for all models. It is now called taskgraph_cache and located in the top level of the workspace directory. (#1230)
    • +
    • InVEST is now distributed under the Apache 2.0 License.
    • +
    +
    +
    +
  • +
  • +
    +
    Workbench
    +
    +
      +
    • Fixed a bug where sampledata downloads failed silently (and progress bar became innacurate) if the Workbench did not have write permission to the download location. https://github.com/natcap/invest/issues/1070
    • +
    • The workbench app is now distributed with a valid code signature (#727)
    • +
    • Changing the language setting will now cause the app to relaunch (#1168)
    • +
    • Closing the main window will now close any user's guide windows that are open. Fixed a bug where the app could not be reopened after closing. (#1258)
    • +
    • Fixed a bug where invalid metadata for a recent run would result in an uncaught exception. (#1286)
    • +
    • Middle clicking an InVEST model tab was opening a blank window. Now middle clicking will close that tab as expected. (#1261)
    • +
    • Updated InVEST logo to use new version with registered trademark symbol. (InVEST TM and Logo Use Policy)
    • +
    • InVEST is licensed using a permissive open source license. But we have decided to add back the license and agreement step to the installer to be upfront and explicit about how InVEST is licensed.
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal Blue Carbon
    +
    +
      +
    • Added validation for the transition table, raising a validation error if unexpected values are encountered. (#729)
    • +
    +
    +
    +
  • +
  • +
    +
    Forest Carbon
    +
    +
      +
    • The biophysical table is now case-insensitive.
    • +
    +
    +
    +
  • +
  • +
    +
    HRA
    +
    +
      +
    • Fixed a bug in HRA where the model would error when all exposure and consequence criteria were skipped for a single habitat. The model now correctly handles this case. https://github.com/natcap/invest/issues/1250
    • +
    • Tables in the .xls format are no longer supported. This format was deprecated by pandas. (#1271)
    • +
    • Fixed a bug where vector inputs could be rasterized onto a grid that is not exactly aligned with other raster inputs. (#1312)
    • +
    • Dropped support for Excel (.xlsx) files (#1391)
    • +
    +
    +
    +
  • +
  • +
    +
    NDR
    +
    +
      +
    • The contents of the output cache_dir have been consolidated into intermediate_outputs.
    • +
    • Fixed a bug where results were calculated incorrectly if the runoff proxy raster (or the DEM or LULC) had no nodata value (#1005)
    • +
    +
    +
    +
  • +
  • +
    +
    Pollination
    +
    + +
    +
    +
  • +
  • +
    +
    RouteDEM
    +
    +
      +
    • RouteDEM now allows the user to calculate Strahler Stream Orders, which will be written to a new vector in the user's workspace. This stream order vector is dependent on the user's Threshold Flow Accumulation value and is only available for the D8 routing model. https://github.com/natcap/invest/issues/884
    • +
    • RouteDEM now allows the user to create a vector of subwatersheds, which are written to a new vector in the user's workspace. This vector is dependent on the calculation of Strahler Stream Orders and is only available for the D8 routing model. https://github.com/natcap/invest/issues/349
    • +
    +
    +
    +
  • +
  • +
    +
    Scenic Quality
    +
    + +
    +
    +
  • +
  • +
    +
    SDR
    +
    +
      +
    • Fixed an issue with sediment deposition progress logging that was causing the "percent complete" indicator to not progress linearly. https://github.com/natcap/invest/issues/1262
    • +
    • The contents of the output churn_dir_not_for_humans have been consolidated into intermediate_outputs.
    • +
    • We implemented two major functional changes to the InVEST LS Factor that significantly affect most outputs of SDR and will bring the LS factor output more in line with the outputs of SAGA-GIS's LS Factor. A discussion of differences between these two implementations can be viewed at https://github.com/natcap/invest/tree/main/doc/decision-records/ADR-0001-Update-SDR-LS-Factor.md. The two specific changes implemented are: +
        +
      • The LS Factor's on-pixel aspect length is now calculated as abs(sin(slope)) + abs(cos(slope)).
      • +
      • The LS Factor's upstream contributing area is now calculated as an estimate for the specific catchment area, calculated by sqrt(n_pixels_upstream * pixel_area).
      • +
      +
    • +
    +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    +
      +
    • Fixed a bug where monthy quickflow nodata pixels were not being passed on to the total quickflow raster, which could result in negative values on the edges (#1105)
    • +
    • Removed the GDAL cache size limit on this model, which means that, by default, the model will use up to 5% of installed memory. https://github.com/natcap/invest/issues/1320
    • +
    • Monthly quick flow nodata values will now be preserved instead of being set to 0. The old behavior was not well documented and caused some confusion when nodata pixels did not line up. It's safer not to fill in unknown data. (#1317)
    • +
    • Negative monthly quickflow values will now be set to 0. This is because very small negative values occasionally result from valid data, but they should be interpreted as 0. (#1318)
    • +
    • In the monthly quickflow calculation, QF_im will be set to 0 on any pixel where s_i / a_im > 100. This is done to avoid overflow errors when calculating edge cases where the result would round down to 0 anyway. (#1318)
    • +
    • The contents of the output cache_dir have been consolidated into intermediate_outputs.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Risk
    +
    +
      +
    • Fixed a bug where the model incorrectly raised an error if the biophysical table contained a row of all 0s. (#1123)
    • +
    • The contents of the output temp_working_dir_not_for_humans have been consolidated into intermediate_files.
    • +
    • Biophysical table Workbench validation now warns if there is a missing curve number value. (#1346)
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Nature Access
    +
    +
      +
    • Urban nature supply outputs have been renamed to add percapita to the filename. +
        +
      • In uniform search radius mode, urban_nature_supply.tif has been renamed to urban_nature_supply_percapita.tif.
      • +
      • When defining search radii by urban nature class, urban_nature_supply_lucode_[LUCODE].tif has been renamed to urban_nature_supply_percapita_lucode_[LUCODE].tif.
      • +
      • When defining search radii by population groups, urban_nature_supply_to_[POP_GROUP].tif has been renamed to urban_nature_supply_percapita_to_[POP_GROUP].tif.
      • +
      +
    • +
    • A new output for "Accessible Urban Nature" is created, indicating the area of accessible greenspace available to people within the search radius, weighted by the selected decay function. The outputs vary slightly depending on the selected execution mode. +
        +
      • In uniform search radius mode, a single new output is created, accessible_urban_nature.tif.
      • +
      • When defining search radii by urban nature class, one new output raster is created for each class of urban nature. These files are named accessible_urban_nature_lucode_[LUCODE].tif.
      • +
      • When defining search radii for population groups, one new output raster is created for each population group. These files are named accessible_urban_nature_to_[POP_GROUP].tif.
      • +
      +
    • +
    • Urban nature classes can now be defined to occupy a proportion of a pixel, such as a park that is semi-developed. This proportion is provided through user input as a proportion (0-1) in the urban_nature column of the LULC Attribute Table. A value of 0 indicates that there is no urban nature in this class, 0.333 indicates that a third of the area of this LULC class is urban nature, and 1 would indicate that the entire LULC class's area is urban nature. https://github.com/natcap/invest/issues/1180
    • +
    • Fixed an issue where, under certain circumstances, the model would raise a cryptic TypeError when creating the summary vector. https://github.com/natcap/invest/issues/1350
    • +
    +
    +
    +
  • +
  • +
    +
    Visitation: Recreation and Tourism
    +
    +
      +
    • Fixed a bug where overlapping predictor polygons would be double-counted in polygon_area_coverage and polygon_percent_coverage calculations. (#1310)
    • +
    • Changed the calculation of point_nearest_distance metric to match the description in the User's Guide. Values are now the distance to the centroid of the AOI polygon instead of the distance to the nearest edge of the AOI polygon. (#1347)
    • +
    +
    +
    +
  • +
  • +
    +
    Wind Energy
    +
    +
      +
    • Updated a misleading error message that is raised when the AOI does not spatially overlap another input. (#1054)
    • +
    +
    +
    +
  • +
+
+
+

3.13.0 (2023-03-17)

+
    +
  • +
    +
    General
    +
    +
      +
    • During builds of the InVEST documentation, the packages sphinx-rtd-theme and sphinx-reredirects will be pulled from conda-forge instead of PyPI. (#1151)
    • +
    • The invest command-line-interface no longer opens a graphical interface to InVEST. (#755)
    • +
    • The classic InVEST user-interface has been removed in favor of the Workbench.
    • +
    • Replace the ARGS_SPEC with MODEL_SPEC which describes all model outputs as well as inputs in a structured format (#596)
    • +
    +
    +
    +
  • +
  • +
    +
    Workbench
    +
    +
      +
    • Added tooltips to the model tabs so that they can be identified even when several tabs are open (#1071)
    • +
    • Options' display names will now be shown in dropdown menus (#1217)
    • +
    • Represent boolean inputs with a toggle switch rather than radio buttons.
    • +
    • Includes local versions of the User Guide in English, Spanish, & Chinese. https://github.com/natcap/invest/issues/851
    • +
    +
    +
    +
  • +
  • +
    +
    DelineateIt
    +
    + +
    +
    +
  • +
  • +
    +
    Habitat Quality
    +
    +
      +
    • The model now uses an euclidean distance implementation for decaying threat rasters both linearly and exponentially. Since InVEST 3.3.0 a convolution implementation has been used, which reflected how the density of a threat or surrounding threat pixels could have an even greater, cumulative impact and degradation over space. However, this was never properly documented in the User's Guide and is not the approach taken in the publication. The convolution implementation also produced degradation and quality outputs that were difficult to interpret.
    • +
    • There should be a noticeable runtime improvement from calculating euclidean distances vs convolutions.
    • +
    +
    +
    +
  • +
  • +
    +
    HRA
    +
    +
      +
    • Fixed an issue where a cryptic exception was being thrown if the criteria table's sections were not spelled exactly as expected. There is now a much more readable error if a section is obviously missing. Leading and trailing whitespace is also now removed from all string fields in the criteria table, which should also help reduce the chance of errors. https://github.com/natcap/invest/issues/1191
    • +
    +
    +
    +
  • +
  • +
    +
    GLOBIO
    +
    +
      +
    • Deprecated the GLOBIO model (#1131)
    • +
    +
    +
    +
  • +
  • +
    +
    RouteDEM
    +
    + +
    +
    +
  • +
  • +
    +
    Scenic Quality
    +
    + +
    +
    +
  • +
  • +
    +
    SDR
    +
    + +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    +
      +
    • If a soil group raster contains any pixels that are not in the set of allowed soil groups (anything other than 1, 2, 3 or 4), a human readable exception will now be raised. https://github.com/natcap/invest/issues/1193
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Nature Access
    +
    +
      +
    • Added the Urban Nature Access model to InVEST. The model for urban nature access provides a measure of both the supply of urban nature and the demand for nature by the urban population, ultimately calculating the balance between supply and demand. See the corresponding User's Guide chapter for documentation.
    • +
    +
    +
    +
  • +
  • +
    +
    Visitation: Recreation and Tourism
    +
    + +
    +
    +
  • +
+
+
+

3.12.1 (2022-12-16)

+
    +
  • +
    +
    General
    +
    +
      +
    • Fixed a possible path traversal vulnerability when working with datastack archives. This patches CVE-2007-4559, reported to us by Trellix. https://github.com/natcap/invest/issues/1113
    • +
    • Added Spanish and Chinese translations of user-facing text and an interface to switch languages in the workbench UI.
    • +
    • Updating descriptions for LULC about text and biophysical table for clarity in model specs. https://github.com/natcap/invest/issues/1077
    • +
    +
    +
    +
  • +
  • +
    +
    Workbench
    +
    +
      +
    • Fixed a bug where the Workbench would become unresponsive during an InVEST model run if the model emitted a very high volume of log messages.
    • +
    • Fixed a bug where the Workbench could crash if there was too much standard error emitted from an invest model.
    • +
    • Added a new "Save as" dialog window to handle different save options, and allow the option to use relative paths in a JSON datastack (#1088)
    • +
    • Fixed a bug where uncaught exceptions in the React tree would result in a blank browser window. (#1119)
    • +
    +
    +
    +
  • +
  • +
    +
    Habitat Quality
    +
    +
      +
    • All spatial inputs including the access vector and threat rasters are now reprojected to the lulc_cur_path raster. This fixes a bug where rasters with a different SRS would appear to not intersect the lulc_cur_path even if they did. (https://github.com/natcap/invest/issues/1093)
    • +
    • Paths in the threats table may now be either absolute or relative to the threats table.
    • +
    +
    +
    +
  • +
  • +
    +
    HRA
    +
    +
      +
    • Fixed a regression relative to InVEST 3.9.0 outputs where spatial criteria vectors were being rasterized with the ALL_TOUCHED=TRUE flag, leading to a perceived buffering of spatial criteria in certain cases. In InVEST 3.9.0, these were rasterized with ALL_TOUCHED=FALSE. https://github.com/natcap/invest/issues/1120
    • +
    • Fixed an issue with the results table, SUMMARY_STATISTICS.csv where the percentages of high, medium and low risk classifications were not correctly reported.
    • +
    • Added a column to the SUMMARY_STATISTICS.csv output table to also report the percentage of pixels within each subregion that have no risk classification (a risk classification of 0).
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Stormwater Retention
    +
    +
      +
    • Added validation to check that the input soil groups raster has an integer data type
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Cooling
    +
    +
      +
    • Updated the text for the building_intensity column in the biophysical table to clarify that the values of this column should be normalized relative to one another to be between 0 and 1.
    • +
    +
    +
    +
  • +
+
+
+

3.12.0 (2022-08-31)

+
    +
  • +
    +
    General
    +
    +
      +
    • Update python packaging settings to exclude a few config files and the workbench from source distributions and wheels
    • +
    • Updating SDR test values due to an update in GDAL's mode resampling algorithm. See https://github.com/natcap/invest/issues/905
    • +
    • Updated our scipy requirement to fix a bug where invest crashed if a Windows user had a non-Latin character in their Windows username.
    • +
    +
    +
    +
  • +
  • +
    +
    Workbench
    +
    +
      +
    • Fixed a bug where some model runs would not generate a new item in the list of recent runs.
    • +
    • Enhanced model input forms so that text boxes always show the rightmost end of the filepath when they overflow the box.
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal Blue Carbon
    +
    +
      +
    • Fixed a bug where using unaligned rasters in the preprocessor would cause an error. The preprocessor will now correctly align input landcover rasters and determine transitions from the aligned rasters.
    • +
    +
    +
    +
  • +
  • +
    +
    Habitat Quality
    +
    +
      +
    • Removed a warning about an undefined nodata value in threat rasters because it is okay for a threat raster to have an undefined nodata value.
    • +
    +
    +
    +
  • +
  • +
    +
    HRA
    +
    +
      +
    • Fixed an issue with risk calculations where risk values would be much lower than they should be. Risk values are now correctly calculated.
    • +
    • Fixed an issue with risk reclassifications where most pixels would end up classified as medium risk.
    • +
    • Added an input field to the model to indicate the number of overlapping stressors to use in risk reclassification calculations. This input affects the numerical boundaries between high, medium and low risk classifications.
    • +
    • Various improvements to the model have resulted in a modest (~33%) speedup in runtime.
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal Vulnerability
    +
    +
      +
    • Fixed a bug where redundant vertices in the landmass polygon could raise an error during shore point creation.
    • +
    +
    +
    +
  • +
  • +
    +
    NDR
    +
    +
      +
    • Added parameters to the sample data to support nitrogen calculations.
    • +
    • Effective retention calculations have been reworked so that the source code more closely matches the mathematical definition in the NDR User's Guide. There should be no difference in outputs.
    • +
    +
    +
    +
  • +
  • +
    +
    SDR
    +
    +
      +
    • We have made a significant update to the SDR model's outputs described here: https://github.com/natcap/peps/blob/main/pep-0010.md. +
        +
      • Legacy outputs sed_retention_index.tif and sed_retention.tif have been removed from the model.
      • +
      • +
        +
        Two new output rasters have been added, specifically
        +
        +
          +
        • avoided_export.tif, indicating vegetation's contribution to reducing erosion on a pixel, as well as trapping of sediment originating upslope of the pixel, so that neither of these proceed downslope to enter a stream.
        • +
        • avoided_erosion.tif, vegetation’s contribution to reducing erosion from a pixel.
        • +
        +
        +
        +
      • +
      • The summary watersheds vector no longer includes the sed_retent field and two fields have been added: +
          +
        • avoid_exp representing the sum of avoided export in the watershed.
        • +
        • avoid_eros representing the sum of avoided erosion in the watershed.
        • +
        +
      • +
      • Sediment deposition, sed_deposition.tif, has been clarified to indicate the sediment that erodes from a pixel goes into the next downstream pixel(s) where it is either trapped or exported. This update removes a form of double-counting.
      • +
      +
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Risk
    +
    +
      +
    • Validation of the curve number table will now catch missing CN_* columns and warn the user about the missing column.
    • +
    +
    +
    +
  • +
+
+
+

3.11.0 (2022-05-24)

+
    +
  • +
    +
    General
    +
    +
      +
    • InVEST Workbench released! A new desktop interface for InVEST models.
    • +
    • Add support for python 3.10, and drop support for python 3.7.
    • +
    • Fixed a bug where the model window would fail to open when using the natcap.invest package with python 3.9.0 - 3.9.3.
    • +
    • spec_utils.ETO has been renamed to spec_utils.ET0 (with a zero).
    • +
    • Updating the pyinstaller requirement to >=4.10 to support the new universal2 wheel architecture offered by scipy>=1.8.0.
    • +
    • Now removing leading / trailing whitespaces from table input values as well as columns in most InVEST models.
    • +
    • Fixing a small bug where drag-and-drop events in the Qt UI were not being handled correctly and were being ignored by the UI.
    • +
    • Expose taskgraph logging level for the cli with --taskgraph-log-level.
    • +
    • Fixed bug in validation of results_suffix so that special characters like path separators, etc, are not allowed.
    • +
    • Fixed a bug in validation where a warning about non-overlapping spatial layers was missing info about the offending bounding boxes.
    • +
    • Fixed an issue with usage logging that caused SSL errors to appear in the Qt interface logging window.
    • +
    +
    +
    +
  • +
  • +
    +
    Annual Water Yield
    +
    +
      +
    • Fixed a bug where the model would error when the watersheds/subwatersheds input was in geopackage format.
    • +
    +
    +
    +
  • +
  • +
    +
    Crop Production
    +
    +
      +
    • Fixed a bug in both crop production models where the model would error if an observed yield raster had no nodata value.
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal Vulnerability
    +
    +
      +
    • Fixed a bug that would cause an error if the user's bathymetry layer did not have a defined nodata value. The user's bathymetry layer should now be correctly preprocessed with or without a nodata value.
    • +
    +
    +
    +
  • +
  • +
    +
    DelineateIt
    +
    +
      +
    • Watersheds delineated with this tool will now always have a ws_id column containing integer watershed IDs for easier use within the routed InVEST models. Existing ws_id field values in the outlets vector will be overwritten if they are present.
    • +
    +
    +
    +
  • +
  • +
    +
    RouteDEM
    +
    +
      +
    • Rename the arg calculate_downstream_distance to calculate_downslope_distance. This is meant to clarify that it applies to pixels that are not part of a stream.
    • +
    +
    +
    +
  • +
  • +
    +
    SDR
    +
    +
      +
    • Fixed an issue with SDR where f.tif might not be recalculated if the file is modified or deleted after execution.
    • +
    • Fixed an issue in sed_deposition.tif and f.tif where pixel values could have very small, negative values for r_i and f_i. These values are now clamped to 0.
    • +
    • Added basic type-checking for the lucode column of the biophysical table. This avoids cryptic numpy errors later in runtime.
    • +
    +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    +
      +
    • Added an output to the model representing total annual precipitation.
    • +
    • Fixed an issue with the documentation for ET0 and Precip directories, where a module-specific informational string was being overridden by a default value.
    • +
    +
    +
    +
  • +
+
+
+

3.10.2 (2022-02-08)

+
    +
  • +
    +
    General
    +
    +
      +
    • The minimum setuptools_scm version has been increased to 6.4.0 in order to bypass calling setup.py for version information. The version of this project can now be retrieved by calling python -m +setuptools_scm from the project root.
    • +
    • Fixed an issue where datastack archives would not include any spatial datasets that were linked to in CSV files. This now works for all models except HRA. If an HRA datastack archive is requested, NotImplementedError will be raised. A fix for HRA is pending.
    • +
    • Pinned numpy versions in pyproject.toml to the lowest compatible version for each supported python version. This prevents issues when natcap.invest is used in an environment with a lower numpy version than it was built with (https://github.com/cython/cython/issues/4452).
    • +
    +
    +
    +
  • +
  • +
    +
    DelineateIt
    +
    +
      +
    • When snapping points to streams, if a point is equally near to more than one stream pixel, it will now snap to the stream pixel with a higher flow accumulation value. Before, it would snap to the stream pixel encountered first in the raster (though this was not guaranteed).
    • +
    +
    +
    +
  • +
  • +
    +
    GLOBIO
    +
    +
      +
    • Gaussian decay kernels are now always tiled, which should result in a minor improvement in model runtime when large decay distances are used.
    • +
    +
    +
    +
  • +
  • +
    +
    Habitat Quality:
    +
    +
      +
    • Linear decay kernels are now always tiled, which should result in a minor improvement in model runtime, particularly with large decay distances.
    • +
    +
    +
    +
  • +
  • +
    +
    HRA
    +
    +
      +
    • Fixed a bug with how a pandas dataframe was instantiated. This bug did not effect outputs though some might notice less trailing zeros in the SUMMARY_STATISTICS.csv output.
    • +
    +
    +
    +
  • +
  • +
    +
    NDR
    +
    +
      +
    • Changed some model inputs and outputs to clarify that subsurface phosphorus is not modeled. +
        +
      • Removed the inputs subsurface_critical_length_p and subsurface_eff_p
      • +
      • Removed the output sub_ndr_p.tif. The model no longer calculates subsurface NDR for phosphorus.
      • +
      • Removed the output sub_load_p.tif. All pixels in this raster were always 0, because the model assumed no subsurface phosphorus movement.
      • +
      • Renamed the output p_export.tif to p_surface_export.tif to clarify that it only models the surface export of phosphorus.
      • +
      • Renamed the output n_export.tif to n_total_export.tif to clarify that it is the total of surface and subsurface nitrogen export.
      • +
      • Added the new outputs n_surface_export.tif and n_subsurface_export.tif, showing the surface and subsurface components of the total nitrogen export.
      • +
      • The aggregate vector output watershed_results_ndr.shp was changed to a geopackage watershed_results_ndr.gpkg.
      • +
      • The aggregate vector fields were given more descriptive names, and updated corresponding to the changed raster outputs: +
          +
        • surf_p_ld was renamed to p_surface_load
        • +
        • surf_n_ld was renamed to n_surface_load
        • +
        • p_exp_tot was renamed to p_surface_export
        • +
        • sub_n_ld was renamed to n_subsurface_load
        • +
        • n_exp_tot was renamed to n_total_export
        • +
        • Added a new field n_surface_export, representing the sum of n_surface_export.tif
        • +
        • Added a new field n_subsurface_export, representing the sum of n_subsurface_export.tif
        • +
        • Removed the field sub_p_ld, since sub_load_p.tif was removed.
        • +
        +
      • +
      +
    • +
    +
    +
    +
  • +
  • +
    +
    Wind Energy
    +
    +
      +
    • Fixed a bug where distance was masking by pixel distance instead of euclidean distance.
    • +
    • Renamed the foundation cost label and help info to reflect it is no longer measured in Millions of US dollars.
    • +
    • Fixed a bug where running valuation with TaskGraph in asynchronous mode would cause the model to error.
    • +
    +
    +
    +
  • +
+
+
+

3.10.1 (2022-01-06)

+
    +
  • +
    +
    Urban Stormwater Retention
    +
    +
      +
    • Fixed a bug where this model's sample data was not available via the Windows installer.
    • +
    +
    +
    +
  • +
+
+
+

3.10.0 (2022-01-04)

+
    +
  • +
    +
    General
    +
    +
      +
    • Add a --language argument to the command-line interface, which will translate model names, specs, and validation messages.
    • +
    • Accept a language query parameter at the UI server endpoints, which will translate model names, specs, and validation messages.
    • +
    • Added invest serve entry-point to the CLI. This launches a Flask app and server on the localhost, to support the workbench.
    • +
    • Major updates to each model's ARGS_SPEC (and some related validation) to facilitate re-use & display in the Workbench and User's Guide.
    • +
    • Standardized and de-duplicated text in ARGS_SPEC about and name strings.
    • +
    • Update to FontAwesome 5 icons in the QT interface.
    • +
    • In response to the deprecation of setup.py-based commands in Python 3.10, the recommended way to build python distributions of natcap.invest is now with the build package, and installation should be done via pip. The README has been updated to reflect this change, and this should only be noticeable for those installing natcap.invest from source.
    • +
    • A bug has been fixed in make install so that now the current version of natcap.invest is built and installed. The former (buggy) version of make install would install whatever the latest version was in your dist folder.
    • +
    • Updating the taskgraph requirement to 0.11.0 to resolve an issue where modifying a file within a roughly 2-second window would fool taskgraph into believing that the file had not been modified.
    • +
    • Fixed a bug where some input rasters with NaN nodata values would go undetected as nodata and yield unexpected behavior.
    • +
    +
    +
    +
  • +
  • +
    +
    Annual Water Yield
    +
    +
      +
    • Renamed the Windows start menu shortcut from "Water Yield" to "Annual Water Yield".
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal Vulnerability
    +
    +
      +
    • Fixed bug where shore points were created on interior landmass holes (i.e. lakes).
    • +
    • Added feature to accept raster (in addition to vector) habitat layers.
    • +
    • Changed one intermediate output (geomorphology) from SHP to GPKG.
    • +
    • Fixed bug where output vectors had coordinates with an unnecessary z-dimension. Output vectors now have 2D geometry.
    • +
    +
    +
    +
  • +
  • +
    +
    Crop Pollination
    +
    +
      +
    • Renamed the Windows start menu shortcut from "Pollination" to "Crop Pollination".
    • +
    +
    +
    +
  • +
  • +
    +
    Fisheries and Fisheries HST
    +
    +
      +
    • The Fisheries models were deprecated due to lack of use, lack of scientific support staff, and maintenance costs.
    • +
    +
    +
    +
  • +
  • +
    +
    Finfish
    +
    +
      +
    • The Finfish model was deprecated due to lack of use, lack of scientific support staff, and maintenance costs.
    • +
    +
    +
    +
  • +
  • +
    +
    Habitat Quality
    +
    +
      +
    • Changed how Habitat Rarity outputs are calculated to be less confusing. Values now represent a 0 to 1 index where before there could be negative values. Now values of 0 indicate current/future LULC not represented in baseline LULC; values 0 to 0.5 indicate more abundance in current/future LULC and therefore less rarity; values of 0.5 indicate same abundance between baseline and current/future LULC; values 0.5 to 1 indicate less abundance in current/future LULC and therefore higher rarity.
    • +
    +
    +
    +
  • +
  • +
    +
    NDR
    +
    +
      +
    • Added a new raster to the model's workspace, intermediate_outputs/what_drains_to_stream[suffix].tif. This raster has pixel values of 1 where DEM pixels flow to an identified stream, and 0 where they do not.
    • +
    +
    +
    +
  • +
  • +
    +
    Scenario Generator
    +
    +
      +
    • Changed an args key from replacment_lucode to replacement_lucode.
    • +
    +
    +
    +
  • +
  • +
    +
    Scenic Quality
    +
    +
      +
    • Simplify the valuation_function arg options. The options are now: linear, logarithmic, exponential. The names displayed in the UI dropdown will stay the same as before. Datastacks or scripts will need to be updated to use the new option values.
    • +
    • Renamed the model title from "Unobstructed Views: Scenic Quality Provision" to "Scenic Quality".
    • +
    +
    +
    +
  • +
  • +
    +
    SDR
    +
    +
      +
    • Added a new raster to the model's workspace, intermediate_outputs/what_drains_to_stream[suffix].tif. This raster has pixel values of 1 where DEM pixels flow to an identified stream, and 0 where they do not.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Risk:
    +
    +
      +
    • Fixed broken documentation link in the user interface.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Stormwater Retention
    +
    +
      +
    • Added this new model
    • +
    +
    +
    +
  • +
  • +
    +
    Visitation: Recreation and Tourism
    +
    +
      +
    • Renamed the Windows start menu shortcut from "Recreation" to "Visitation: Recreation and Tourism".
    • +
    +
    +
    +
  • +
  • +
    +
    Wave Energy
    +
    +
      +
    • Rename the analysis_area_path arg to analysis_area, since it is not a path but an option string.
    • +
    • Simplify the analysis_area arg options. The options are now: westcoast, eastcoast, northsea4, northsea10, australia, global. The names displayed in the UI dropdown will stay the same as before. Datastacks and scripts will need to be updated to use the new option values.
    • +
    +
    +
    +
  • +
  • +
    +
    Wind Energy
    +
    +
      +
    • No model inputs or outputs are measured in "millions of" currency units any more. Specifically:
    • +
    • The mw_coef_ac and mw_coef_dc values in the Global Wind Energy Parameters table were in millions of currency units per MW; now they should be provided in currency units per MW.
    • +
    • The infield_cable_cost, cable_coef_ac, and cable_coef_dc values in the Global Wind Energy Parameters table were in millions of currency units per km; now they should be provided in currency units per km.
    • +
    • The turbine_cost value in the Turbine Parameters table was in millions of currency units; now it should be provided in currency units.
    • +
    • The foundation_cost parameter was in millions of currency units; now it should be provided in currency units.
    • +
    • The NPV output, formerly npv_US_millions.tif, is now npv.tif. It is now in currency units, not millions of currency units.
    • +
    +
    +
    +
  • +
+
+
+

3.9.2 (2021-10-29)

+
    +
  • +
    +
    General:
    +
    +
      +
    • Improving our binary build by including a data file needed for the charset-normalizer python package. This eliminates a warning that was printed to stdout on Windows.
    • +
    • The Annual Water Yield model name is now standardized throughout InVEST. This model has been known in different contexts as Hydropower, Hydropower Water Yield, or Annual Water Yield. This name was chosen to emphasize that the model can be used for purposes other than hydropower (though the valuation component is hydropower-specific) and to highlight its difference from the Seasonal Water Yield model. The corresponding python module, formerly natcap.invest.hydropower.hydropower_water_yield, is now natcap.invest.annual_water_yield.
    • +
    • Minor changes to some other models' display names.
    • +
    • Update and expand on the instructions in the API docs for installing the natcap.invest package.
    • +
    • The InVEST binaries on Windows now no longer inspect the %PATH% when looking for GDAL DLLs. This fixes an issue where InVEST would not launch on computers where the %PATH% either contained other environment variables or was malformed.
    • +
    • invest processes announce their logfile path at a very high logging level that cannot be filtered out by the user.
    • +
    • JSON sample data parameter sets are now included in the complete sample data archives.
    • +
    +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    +
      +
    • Fixed a bug in validation where providing the monthly alpha table would cause a "Spatial file <monthly alpha table> has no projection" error. The montly alpha table was mistakenly being validated as a spatial file.
    • +
    +
    +
    +
  • +
  • +
    +
    Crop Production Regression
    +
    +
      +
    • Corrected a misspelled column name. The fertilization rate table column must now be named phosphorus_rate, not phosphorous_rate.
    • +
    +
    +
    +
  • +
  • +
    +
    Habitat Quality
    +
    +
      +
    • Fixed a bug where optional input Allow Accessibility to Threats could not be passed as an empty string argument. Now handles falsey values.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Risk
    +
    +
      +
    • Fixed a bug where lucodes present in the LULC raster but missing from the biophysical table would either raise a cryptic IndexError or silently apply invalid curve numbers. Now a helpful ValueError is raised.
    • +
    +
    +
    +
  • +
+
+
+

3.9.1 (2021-09-22)

+
    +
  • +
    +
    General:
    +
    +
      +
    • Added error-handling for when pandas fails to decode a non-utf8 encoded CSV.
    • +
    • Moved the sample data JSON files out of the root sample_data folder and into their respective model folders.
    • +
    • Updated documentation on installing InVEST from source.
    • +
    • Restructured API reference docs and removed outdated and redundant pages.
    • +
    • Include logger name in the logging format. This is helpful for the cython modules, which can't log module, function, or line number info.
    • +
    • Fixed a bug in makefile that prevented make env from working properly.
    • +
    • Fixed an issue with the InVEST application launching on Mac OS X 11 "Big Sur". When launching the InVEST .app bundle, the environment variable QT_MAC_WANTS_LAYER is defined. If running InVEST through python, this environment variable may need to be defined by hand like so: QT_MAC_WANTS_LAYER=1 python -m natcap.invest. A warning will be raised if this environment variable is not present on mac.
    • +
    • Fixing an issue on Mac OS X where saving the InVEST application to a filepath containing spaces would prevent the application from launching.
    • +
    • Fixed an issue on Mac OS when certain models would loop indefinitely and never complete. This was addressed by bumping the taskgraph requirement version to 0.10.3
    • +
    • Allow Windows users to install for all users or current user. This allows non-admin users to install InVEST locally.
    • +
    • Fixed a bug where saving a datastack parameter set with relative paths would not convert Windows separators to linux style.
    • +
    • Provide a better validation error message when an overview '.ovr' file is input instead of a valid raster.
    • +
    • Removed internal references to TaskGraph copy_duplicate_artifact calls in anticipation from that feature being removed from TaskGraph. User facing changes include slightly faster initial runtimes for the Coastal Vulnerability, Coastal Blue Carbon, SDR, DelineateIt, and Seasonal Water Yield models. These models will no longer attempt to copy intermediate artifacts that could have been computed by previous runs.
    • +
    • Validation now returns a more helpful message when a spatial input has no projection defined.
    • +
    • Updated to pygeoprocessing 2.3.2
    • +
    • Added support for GDAL 3.3.1 and above
    • +
    • Added some logging to natcap.invest.utils._log_gdal_errors to aid in debugging some hard-to-reproduce GDAL logging errors that occasionally cause InVEST models to crash. If GDAL calls _log_gdal_errors with an incorrect set of arguments, this is now logged.
    • +
    • Improved the reliability and consistency of log messages across the various ways that InVEST models can be run. Running InVEST in --headless mode, for example, will now have the same logging behavior, including with exceptions, as the UI would produce.
    • +
    • The default log level for the CLI has been lowered from logging.CRITICAL to logging.ERROR. This ensures that exceptions should always be written to the correct logging streams.
    • +
    +
    +
    +
  • +
  • +
    +
    Carbon
    +
    +
      +
    • Fixed a bug where, if rate change and discount rate were set to 0, the valuation results were in $/year rather than $, too small by a factor of lulc_fut_year - lulc_cur_year.
    • +
    • Improved UI to indicate that Calendar Year inputs are only required for valuation, not also for sequestration.
    • +
    • Increasing the precision of numpy.sum from Float32 to Float64 when aggregating raster values for the HTML report.
    • +
    +
    +
    +
  • +
  • +
    +
    DelineateIt:
    +
    +
      +
    • The DelineateIt UI has been updated so that the point-snapping options will always be interactive.
    • +
    • DelineateIt's point-snapping routine has been updated to snap MULTIPOINT geometries with 1 component point as well as primitive POINT geometries. All other geometric types will not be snapped. When a geometry cannot be snapped, a log message is now recorded with the feature ID, the geometry type and the number of component geometries. Features with empty geometries are now also skipped.
    • +
    +
    +
    +
  • +
  • +
    +
    Fisheries Habitat Scenario Tool
    +
    +
      +
    • Fixed divide-by-zero bug that was causing a RuntimeWarning in the logs. This bug did not affect the output.
    • +
    +
    +
    +
  • +
  • +
    +
    HRA
    +
    +
      +
    • Fixed bugs that allowed zeros in DQ & Weight columns of criteria table to raise DivideByZero errors.
    • +
    +
    +
    +
  • +
  • +
    +
    NDR
    +
    +
      +
    • Fixed a bug that allowed SDR to be calculated in areas that don't drain to any stream. Now all outputs that depend on distance to stream ( d_dn, dist_to_channel, ic, ndr_n, ndr_p, sub_ndr_n, sub_ndr_p, n_export, p_export) are only defined for pixels that drain to a stream. They have nodata everywhere else.
    • +
    +
    +
    +
  • +
  • +
    +
    Pollination
    +
    +
      +
    • Updated so that the total_pollinator_abundance_[season].tif outputs are always created. Before, they weren't created if a farm vector was not supplied, even though they are independent.
    • +
    +
    +
    +
  • +
  • +
    +
    Recreation
    +
    +
      +
    • Fixed some incorrectly formatted log and error messages
    • +
    +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    +
      +
    • Fixed a bug where qf.tif outputs weren't properly masking nodata values and could show negative numbers.
    • +
    +
    +
    +
  • +
  • +
    +
    SDR
    +
    +
      +
    • Fixed a bug in validation that did not warn against different coordinate systems (all SDR inputs must share a common coordinate system).
    • +
    • Fixed a bug that was incorrectly using a factor of 0.0986 rather than 0.0896. This would have a minor effect on end-user results.
    • +
    • Changed how SDR thresholds its L factor to allow direct thresholding rather than based off of upstream area. Exposed this parameter as l_max in the args input and in the user interface.
    • +
    • Fixed a bug that allowed SDR to be calculated in areas that don't drain to any stream. Now all outputs that depend on distance to stream ( d_dn, d_dn_bare, ic, ic_bare, sdr, sdr_bare, e_prime, sed_retention, sed_retention_index, sed_deposition, sed_export) are only defined for pixels that drain to a stream. They have nodata everywhere else.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Risk
    +
    +
      +
    • Fixed a bug where a String Type column in the infrastructure vector would cause the aggregation step of the model to crash, even with the correct integer value in the column.
    • +
    +
    +
    +
  • +
  • +
    +
    Wind Energy
    +
    +
      +
    • Raising ValueError when AOI does not intersect Wind Data points.
    • +
    +
    +
    +
  • +
+
+
+

3.9.0 (2020-12-11)

+
    +
  • +
    +
    General:
    +
    +
      +
    • Deprecating GDAL 2 and adding support for GDAL 3.
    • +
    • Adding function in utils.py to handle InVEST coordindate transformations.
    • +
    • +
      +
      Making InVEST compatible with Pygeoprocessing 2.0 by updating:
      +
      +
        +
      • convolve_2d() keyword ignore_nodata to ignore_nodata_and_edges.
      • +
      • get_raster_info() / get_vector_info() keyword projection to projection_wkt.
      • +
      +
      +
      +
    • +
    • Improve consistency and context for error messages related to raster reclassification across models by using utils.reclassify_raster.
    • +
    • Fixed bug that was causing a TypeError when certain input rasters had an undefined nodata value. Undefined nodata values should now work everywhere.
    • +
    • Include logging in python script generated from "Save to python script..." in the "Development" menu. Now logging messages from the model execution will show up when you run the script.
    • +
    • InVEST is now a 64-bit binary built against Python 3.7.
    • +
    • Adding Python 3.8 support for InVEST testing.
    • +
    • Add warning message to installer for 32-bit computers about installing 64-bit software.
    • +
    • Stop running validation extra times when model inputs autofill, saving a small but noticeable amount of time in launching a model.
    • +
    • The number of files included in the python source distribution has been reduced to just those needed to install the python package and run tests.
    • +
    • Code-sign the macOS distribution, and switch to a DMG distribution format.
    • +
    • No longer include the HTML docs or HISTORY.rst in the macOS distribution.
    • +
    • Bumped the shapely requirements to >=1.7.1 to address a library import issue on Mac OS Big Sur.
    • +
    • Fixing model local documentation links for Windows and Mac binaries.
    • +
    • The InVEST binary builds now launch on Mac OS 11 "Big Sur". This was addressed by defining the QT_MAC_WANTS_LAYER environment variable.
    • +
    • Fixed the alphabetical ordering of Windows Start Menu shortcuts.
    • +
    +
    +
    +
  • +
  • +
    +
    Annual Water Yield:
    +
    +
      +
    • Fixing bug that limited rsupply result when wyield_mn or consump_mn was 0.
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal Blue Carbon
    +
    +
      +
    • Refactor of Coastal Blue Carbon that implements TaskGraph for task management across the model and fixes a wide range of issues with the model that were returning incorrect results in all cases.
    • +
    • Corrected an issue with the model where available memory would be exhausted on a large number of timesteps.
    • +
    • In addition to the execute entrypoint, another entrypoint, execute_transition_analysis has been added that allows access to the transition analysis timeseries loop at a lower level. This will enable users comfortable with python to provide spatially-explicit maps of accumulation rates, half lives and other parameters that can only be provided via tables to execute.
    • +
    • Snapshot years and rasters, including the baseline year/raster, are now all provided via a table mapping snapshot years to the path to a raster on disk. The baseline year is the earliest year of these.
    • +
    • The model's "initial" and "lulc lookup" and "transient" tables have been combined into a single "biophysical" table, indexed by LULC code/LULC class name, that includes all of the columns from all of these former tables.
    • +
    • The "analysis year" is now a required input that must be >= the final snapshot year in the snapshots CSV.
    • +
    • Litter can now accumulate at an annual rate if desired.
    • +
    • The model now produces many more files, which allows for greater flexibility in post-processing of model outputs.
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal Vulnerability
    +
    +
      +
    • 'shore_points_missing_geomorphology.gpkg' output file name now includes the suffix if any, and its one layer now is renamed from 'missing_geomorphology' to be the same as the file name (including suffix).
    • +
    • Fixed a memory bug that occurred during shore point interpolation when dealing with very large landmass vectors.
    • +
    +
    +
    +
  • +
  • +
    +
    Delineateit
    +
    +
      +
    • The layer in the 'preprocessed_geometries.gpkg' output is renamed from 'verified_geometries' to be the same as the file name (including suffix).
    • +
    • The layer in the 'snapped_outlets.gpkg' output is renamed from 'snapped' to be the same as the file name (including suffix).
    • +
    • The layer in the 'watersheds.gpkg' output has been renamed from 'watersheds' to match the name of the vector file (including the suffix).
    • +
    • Added pour point detection option as an alternative to providing an outlet features vector.
    • +
    +
    +
    +
  • +
  • +
    +
    Finfish
    +
    +
      +
    • Fixed a bug where the suffix input was not being used for output paths.
    • +
    +
    +
    +
  • +
  • +
    +
    Forest Carbon Edge Effect
    +
    +
      +
    • Fixed a broken link to the local User's Guide
    • +
    • Fixed bug that was causing overflow errors to appear in the logs when running with the sample data.
    • +
    • Mask out nodata areas of the carbon map output. Now there should be no output data outside of the input LULC rasater area.
    • +
    +
    +
    +
  • +
  • +
    +
    GLOBIO
    +
    +
      +
    • Fixing a bug with how the msa results were masked and operated on that could cause bad results in the msa outputs.
    • +
    +
    +
    +
  • +
  • +
    +
    Habitat Quality:
    +
    +
      +
    • Refactor of Habitat Quality that implements TaskGraph
    • +
    • Threat files are now indicated in the Threat Table csv input under required columns: BASE_PATH, CUR_PATH, FUT_PATH.
    • +
    • Threat and Sensitivity column names are now case-insensitive.
    • +
    • Sensitivity threat columns now match threat names from Threat Table exactly, without the need for L_. L_ prefix is deprecated.
    • +
    • Threat raster input folder has been removed.
    • +
    • Validation enhancements that check whether threat raster paths are valid.
    • +
    • HQ update to User's Guide.
    • +
    • Changing sample data to reflect Threat Table csv input changes and bumping revision.
    • +
    • More comprehensive testing for Habitat Quality and validation.
    • +
    • Checking if Threat raster values are between 0 and 1 range, raising ValueError if not. No longer snapping values less than 0 to 0 and greater than 1 to 1.
    • +
    • Fixing bug that was setting Threat raster values to 1 even if they were floats between 0 and 1.
    • +
    • Updating how threats are decayed across distance. Before, nodata edges were ignored causing values on the edges to maintain a higher threat value. Now, the decay does not ignore those nodata edges causing values on the edges to decay more quickly. The area of study should have adequate boundaries to account for these edge effects.
    • +
    • Update default half saturation value for sample data to 0.05 from 0.1.
    • +
    +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    +
      +
    • Fixed a bug where precip or eto rasters of GDT_Float64 with values greater than 32-bit would overflow to -inf.
    • +
    +
    +
    +
  • +
  • +
    +
    SDR:
    +
    +
      +
    • Fixing an issue where the LS factor should be capped to an upstream area of 333^2 m^2. In previous versions the LS factor was erroneously capped to "333" leading to high export spikes in some pixels.
    • +
    • Fixed an issue where sediment deposition progress logging was not progressing linearly.
    • +
    • Fixed a task dependency bug that in rare cases could cause failure.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Cooling
    +
    +
      +
    • Split energy savings valuation and work productivity valuation into separate UI options.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Risk
    +
    +
      +
    • Changed output field names aff.bld and serv.blt to aff_bld and serv_blt respectively to fix an issue where ArcGIS would not display properly.
    • +
    +
    +
    +
  • +
+
+
+

3.8.9 (2020-09-15)

+
    +
  • +
    +
    Hydropower
    +
    +
      +
    • Fixed bug that prevented validation from ever passing for this model. Validation will allow extra keys in addition to those in the ARGS_SPEC.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Mitigation
    +
    +
      +
    • Fixed incorrect calculation of total quickflow volume.
    • +
    +
    +
    +
  • +
+
+
+

3.8.8 (2020-09-04)

+
    +
  • +
    +
    Coastal Vulnerability
    +
    +
      +
    • Improved handling of invalid AOI geometries to avoid crashing and instead fix the geometry when possible and skip it otherwise.
    • +
    • Added validation check that shows a warning if the SLR vector is not a point or multipoint geometry.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Cooling
    +
    +
      +
    • Energy units are now (correctly) expressed in kWh. They were previously (incorrectly) expressed in kW.
    • +
    • Energy savings calculations now require that consumption is in units of kWh/degree C/m^2 for each building class.
    • +
    • Fixing an issue where blank values of the Cooling Coefficient weights (shade, albedo, ETI) would raise an error. Now, a default value for the coefficient is assumed if any single value is left blank.
    • +
    +
    +
    +
  • +
  • +
    +
    HRA
    +
    +
      +
    • Raise ValueError if habitat or stressor inputs are not projected.
    • +
    • Make sample data rating filepaths work on Mac. If not on Windows and a rating filepath isn't found, try replacing all backslashes with forward slashes.
    • +
    +
    +
    +
  • +
  • +
    +
    Seasonal Water Yield
    +
    +
      +
    • Updated output file name from aggregated_results.shp to aggregated_results_swy.shp for consistency with NDR and SDR
    • +
    +
    +
    +
  • +
  • +
    +
    Datastack
    +
    +
      +
    • Saved datastack archives now use helpful identifying names for spatial input folders
    • +
    +
    +
    +
  • +
  • +
    +
    Validation
    +
    +
      +
    • Fixed bug that caused fields activated by a checkbox to make validation fail, even when the checkbox was unchecked.
    • +
    +
    +
    +
  • +
  • +
    +
    General
    +
    +
      +
    • Input table column headers are now insensitive to leading/trailing whitespace in most places.
    • +
    • Modified the script that produces a conda environment file from InVEST's python requirements file so that it includes the conda-forge channel in the file itself.
    • +
    +
    +
    +
  • +
  • +
    +
    Recreation
    +
    +
      +
    • Validate values in the type column of predictor tables early in execution. Raise a ValueError if a type value isn't valid (leading/trailing whitespace is okay).
    • +
    +
    +
    +
  • +
  • +
    +
    Validation
    +
    +
      +
    • Set a 5-second timeout on validation functions that access a file. This will raise a warning and prevent validation from slowing down the UI too much.
    • +
    +
    +
    +
  • +
+
+
+

3.8.7 (2020-07-17)

+
    +
  • +
    +
    General
    +
    +
      +
    • Fixed an issue where some users would be unable to launch InVEST binaries on Windows. This crash was due to a configuration issue in PySide2==5.15.0 that will be fixed in a future release of PySide2.
    • +
    +
    +
    +
  • +
  • +
    +
    GLOBIO
    +
    +
      +
    • Fix a bug that mishandled combining infrastructure data when only one infrastructure data was present.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Risk
    +
    +
      +
    • The output vector flood_risk_service.shp now includes a field, flood_vol that is the sum of the modeled flood volume (from Q_m3.tif) within the AOI.
    • +
    • Fieldnames in flood_risk_service.shp have been updated to more closely match the variables they match as documented in the User's Guide chapter. Specifically, serv_bld is now serv.blt and aff_bld is now aff.bld.
    • +
    • Q_mm.tif has been moved from the intermediate directory into the workspace.
    • +
    • Fixed a bug in the flood volume (Q_m3.tif) calculations that was producing incorrect values in all cases.
    • +
    • Fixed a bug where input rasters with nodata values of 0 were not handled properly.
    • +
    +
    +
    +
  • +
+
+
+

3.8.6 (2020-07-03)

+
    +
  • +
    +
    Crop Production
    +
    +
      +
    • Fixed critical bug in crop regression that caused incorrect yields in all cases.
    • +
    +
    +
    +
  • +
+
+
+

3.8.5 (2020-06-26)

+
    +
  • +
    +
    General
    +
    +
      +
    • Fix bug in utils.build_lookup_from_csv that was allowing key_field to be non unique and overwriting values.
    • +
    • Fix bug in utils.build_lookup_from_csv where trailing commas caused returned values to be malformed.
    • +
    • Add optional argument column_list to utils.build_lookup_from_csv that takes a list of column names and only returns those in the dictionary.
    • +
    • Remove warn_if_missing argument from utils.build_lookup_from_csv and warning by default.
    • +
    +
    +
    +
  • +
  • +
    +
    Scenic Quality
    +
    +
      +
    • Fixing an issue in Scenic Quality where the creation of the weighted sum of visibility rasters could cause "Too Many Open Files" errors and/or MemoryError when the model is run with many viewpoints.
    • +
    • Progress logging has been added to several loops that may take a longer time when the model is run with thousands of points at a time.
    • +
    • A major part of the model's execution was optimized for speed, particularly when the model is run with many, many points.
    • +
    +
    +
    +
  • +
  • +
    +
    SDR:
    +
    +
      +
    • Removed the unused parameter args['target_pixel_size'] from the SDR execute docstring.
    • +
    +
    +
    +
  • +
  • +
    +
    Urban Flood Risk Mitigation
    +
    +
      +
    • Fixed an issue where the output vector flood_risk_service.shp would only be created when the built infrastructure vector was provided. Now, the flood_risk_service.shp vector is always created, but the fields created differ depending on whether the built infrastructure input is present during the model run.
    • +
    • Fixed an issue where the model would crash if an infrastructure geometry were invalid or absent. Such features are now skipped.
    • +
    +
    +
    +
  • +
+
+
+

3.8.4 (2020-06-05)

+
    +
  • +
    +
    General:
    +
    +
      +
    • Advanced the Taskgraph version requirement to fix a bug where workspace directories created by InVEST versions <=3.8.0 could not be re-used by more recent InVEST versions.
    • +
    +
    +
    +
  • +
  • +
    +
    NDR:
    +
    +
      +
    • The Start Menu shortcut on Windows and launcher label on Mac now have consistent labels for NDR: "NDR: Nutrient Delivery Ratio".
    • +
    +
    +
    +
  • +
  • +
    +
    SDR:
    +
    +
      +
    • The Start Menu shortcut on Windows and launcher label on Mac now have consistent labels for SDR: "SDR: Sediment Delivery Ratio".
    • +
    +
    +
    +
  • +
+
+
+

3.8.3 (2020-05-29)

+
    +
  • +
    +
    SDR
    +
    +
      +
    • SDR's compiled core now defines its own SQRT2 instead of relying on an available standard C library definition. This new definition helps to avoid some compiler issues on Windows.
    • +
    +
    +
    +
  • +
+
+
+

3.8.2 (2020-05-15)

+
    +
  • InVEST's CSV encoding requirements are now described in the validation error message displayed when a CSV cannot be opened.
  • +
+
+
+

3.8.1 (2020-05-08)

+
    +
  • Fixed a compilation issue on Mac OS X Catalina.
  • +
  • Fixed an issue with NDR's raster normalization function so that Float64 nodata values are now correctly cast to Float32. This issue was affecting the summary vector, where the surf_n, sub_n and n_export_tot columns would contain values of -inf.
  • +
  • Fixed minor bug in Coastal Vulnerability shore point creation. Also added a check to fail fast when zero shore points are found within the AOI.
  • +
  • The Finfish Aquaculture model no longer generates histograms for uncertainty analysis due to issues with matplotlib that make InVEST unstable. See https://github.com/natcap/invest/issues/87 for more.
  • +
  • Corrected the Urban Cooling Model's help text for the "Cooling Capacity Calculation Method" in the User Interface.
  • +
  • Fixing an issue with SDR's LS calculations. The x term is now the weighted mean of proportional flow from the current pixel into its neighbors. Note that for ease of debugging, this has been implemented as a separate raster and is now included in RKLS calculations instead of in the LS calculations.
  • +
  • Fixed a bug in validation where checking for spatial overlap would be skipped entirely in cases where optional model arguments were not used.
  • +
  • Bumping the psutil dependency requirement to psutil>=5.6.6 to address a double-free vulnerability documented in CVE-2019-18874.
  • +
  • Adding a GitHub Actions workflow for building python wheels for Mac and Windows as well as a source distribution.
  • +
  • Updating links in setup.py, README.rst and README_PYTHON.rst to refer to the repository's new home on github.
  • +
  • Binary builds for Windows and Mac OS X have been moved to GitHub Actions from AppVeyor. All AppVeyor-specific configuration has been removed.
  • +
  • Fixing an issue with the InVEST Makefile where make deploy was attempting to synchronize nonexistent sample data zipfiles with a storage bucket on GCP. Sample data zipfiles are only built on Windows, and so make deploy will only attempt to upload them when running on Windows.
  • +
  • Fixed a bug in CLI logging where logfiles created by the CLI were incompatible with the natcap.invest.datastack operation that allows the UI to load model arguments from logfiles.
  • +
  • Added error-handling in Urban Flood Risk Mitigation to tell users to "Check that the Soil Group raster does not contain values other than (1, 2, 3, 4)" when a ValueError is raised from _lu_to_cn_op.
  • +
  • Updated the Makefile to use the new git location of the InVEST User's Guide repository at https://github.com/natcap/invest.users-guide
  • +
  • Automated tests are now configured to use Github Actions for 32- and 64-bit build targets for Python 3.6 and 3.7 on Windows. We are still using AppVeyor for our binary builds for the time being.
  • +
  • Makefile has been updated to fetch the version string from git rather than hg. A mercurial client is still needed in order to clone the InVEST User's Guide.
  • +
  • Removing Python 2 compatibility code such as future, pyqt4, basestring, unicode, six, unicode casting, etc...
  • +
  • Update api-docs conf file to mock sdr.sdr_core and to use updated unittest mock
  • +
+
+
+

3.8.0 (2020-02-07)

+
    +
  • Created a sub-directory for the sample data in the installation directory.
  • +
  • Fixed minor bug in HRA that was duplicating the results_suffix in some output filenames.
  • +
  • Updated the DelineateIt UI to improve the language around what the model should do when it encounters invalid geometry. The default is now that it should skip invalid geometry.
  • +
  • Updating how threat rasters are handled in Habitat Quality to address a few related and common usability issues for the model. First, threat rasters are now aligned to the LULC instead of the intersection of the whole stack. This means that the model now handles threat inputs that do not all completely overlap the LULC (they must all still be in the same projection). Second, nodata values in threat rasters are converted to a threat value of 0. Any threat pixel values other than 0 or nodata are interpreted as a threat value of 1.
  • +
  • Updating the psutil requirement to avoid a possible import issue when building binaries under WINE. Any version of psutil should work except for 5.6.0.
  • +
  • InVEST sample data was re-organized to simply have one folder per model. New datastacks were added for SDR, NDR, Seasonal Water Yield, Annual Water Yield, DelineateIt, and Coastal Vulnerability.
  • +
  • Fixed an issue with NDR where the model was not properly checking for the bounds of the raster, which could in some cases lead to exceptions being printed to the command-line. The model now correctly checks for these raster boundaries.
  • +
  • Habitat Risk Assessment model supports points and lines -- in addition to previously supported polygons and rasters -- for habitats or stressors.
  • +
  • Updated raster percentile algorithms in Scenic Quality and Wave Energy models to use a more efficient and reliable raster percentile function from pygeoprocessing.
  • +
  • InVEST is now compatible with pygeoprocessing 1.9.1.
  • +
  • All InVEST models now have an ARGS_SPEC object that contains metadata about the model and describes the model's arguments. Validation has been reimplemented across all models to use these ARGS_SPEC objects.
  • +
  • The results suffix key for the Wave Energy and Wind Energy models has been renamed results_suffix (was previously suffix). This is for consistency across InVEST models.
  • +
  • Speed and memory optimization of raster processing in the Recreation model.
  • +
  • Removed a constraint in Coastal Vulnerability so the AOI polygon no longer needs to intersect the continental shelf contour line. So the AOI can now be used exclusively to delineate the coastal area of interest.
  • +
  • Improved how Coastal Vulnerability calculates local wind-driven waves. This requires a new bathymetry raster input and implements equation 10 of the User Guide. Also minor updates to fields in intermediate outputs, notably a 'shore_id' field is now the unique ID for joining tables and FIDs are no longer used.
  • +
  • Added a status message to the UI if a datastack file fails to load, instead of staying silent.
  • +
  • Correcting an issue with repository fetching in the InVEST Makefile. Managed repositories will now be fetched and updated to the expected revision even if the repository already exists.
  • +
  • Fixed the duplicate results_suffix input in Wave Energy UI.
  • +
  • Added a human-friendly message on NDR model KeyError.
  • +
  • Adding a check to Annual Water Yield to ensure that the LULC_veg column has correct values.
  • +
  • Improved how Seasonal Water Yield handles nodata values when processing floating-point precipitation and quickflow rasters.
  • +
  • Add SDR feature to model sediment deposition across the landscape.
  • +
  • Fixed an issue that would cause an exception if SDR landcover map was masked out if the original landcover map had no-nodata value defined.
  • +
  • Fixed an issue in the SDR model that could cause reported result vector values to not correspond with known input vectors if the input watershed vector was not an ESRI Shapefile.
  • +
  • Fixed issue in Seasonal Water Yield model that would cause an unhandled exception when input rasters had areas of a valid DEM but nodata in other input layers that overlap that dem.
  • +
  • Fixed an issue in the NDR model that would cause an exception if the critical length of a landcover field was set to 0.
  • +
  • Implemented PEP518-compatible build system definition in the file pyproject.toml. This should make it easier to install natcap.invest from a source distribution.
  • +
  • Fixed a TypeError issue in Seasonal Water Yield that would occur when the Land-Use/Land-Cover raster did not have a defined nodata value. This case is now handled correctly.
  • +
  • The binary build process for InVEST on Windows (which includes binaries based on PyInstaller and an NSIS Installer package) has been migrated to 32-bit Python 3.7. The build itself is taking place on AppVeyor, and the configuration for this is contained within appveyor.yml. Various python scripts involved in the distribution and release processes have been updated for compatibility with python 3.7 as a part of this migration.
  • +
  • Fixed an IndexError issue in Wave Energy encountered in runs using the global wave energy dataset. This error was the result of an incorrect spatial query of points and resulted in some wave energy points being double-counted.
  • +
  • Fixed taskgraph-related issues with Habitat Risk Assessment where 1) asynchronous mode was failing due to missing task dependencies and 2) avoided recomputation was confounded by two tasks modifying the same files.
  • +
  • Fixed an issue with Habitat Quality where the model was incorrectly expecting the sensitivity table to have a landcover code of 0.
  • +
  • The InVEST CLI has been completely rebuilt to divide functionality into various topic-specific subcommands. The various internal consumers of this API have been updated accordingly. invest --help will contain details of the new interface.
  • +
  • Updated the InVEST Launcher to list the human-readable model names rather than the internal model identifiers.
  • +
  • Updated Coastal Vulnerability Model with significant speedups including ~40x speedup for geomorphology process and ~3x speedup for wind exposure process. Also saving an intermediate vector with wave energy values and a geomorphology vector with points that were assigned the geomorphology_fill_value.
  • +
  • Updated trove classifiers to indicate support for python versions 2.7, 3.6 and 3.7.
  • +
  • Updated all InVEST models to be compatible with a Python 2.7 or a Python 3.6 environment. Also tested all models against GDAL versions 2.2.4 and 2.4.1.
  • +
  • Fixed an issue with Habitat Quality where convolutions over threat rasters were not excluding nodata values, leading to incorrect outputs. Nodata values are now handled correctly and excluded from the convolution entirely.
  • +
  • Updated the subpackage natcap.invest.ui to work with python 3.6 and later and also to support the PySide2 bindings to Qt5.
  • +
  • InVEST Coastal Blue Carbon model now writes out a net present value raster for the year of the current landcover, each transition year, and the final analysis year (if provided).
  • +
  • Correcting an issue with InVEST Coastal Blue Carbon where incorrect configuration of a nodata value would result in -inf values in output rasters. Now, any values without a defined reclassification rule that make it past validation will be written out as nodata.
  • +
  • DelineateIt has been reimplemented using the latest version of pygeoprocessing (and the watershed delineation routine it provides) and now uses taskgraph for avoiding unnecessary recomputation.
  • +
  • Fixed a bug in Recreation Model that was causing server-side code to execute twice for every client-side call.
  • +
  • Fixed a bug in Recreation model that did not apply results_suffix to the monthly_table.csv output.
  • +
  • Various fixes in Coastal Vulnerability Model. CSV output files now have FID column for joining to vector outputs. results_suffix can be used without triggering task re-execution. Raster processing maintains original resolution of the input raster so long as it is projected. Otherwise resamples to model_resolution.
  • +
  • Fixed a bug in Coastal Vulnerability model's task graph that sometimes caused an early task to re-execute when it should be deemed pre-calculated.
  • +
  • Fixed a bug in the pollination model that would cause outputs to be all 0 rasters if all the relative_abundance fields in the guild table were integers.
  • +
  • Fixed a file cache flushing issue observed on Debian in utils.exponential_decay_kernel_raster that would cause an exponential kernel raster to contain random values rather than expected value.
  • +
  • Added a new InVEST model: Urban Flood Risk Mitigation.
  • +
  • Fixed an issue in the SDR model that would cause an unhandled exception if either the erosivity or erodibility raster had an undefined nodata value.
  • +
  • Added a new InVEST model: Urban Cooling Model.
  • +
+
+
+

3.7.0 (2019-05-09)

+
    +
  • Refactoring Coastal Vulnerability (CV) model. CV now uses TaskGraph and Pygeoprocessing >=1.6.1. The model is now largely vector-based instead of raster-based. Fewer input datasets are required for the same functionality. Runtime in sycnhronous mode is similar to previous versions, but runtime can be reduced with multiprocessing. CV also supports avoided recomputation for successive runs in the same workspace, even if a different file suffix is used. Output vector files are in CSV and geopackage formats.
  • +
  • Model User Interface 'Report an Issue' link points to our new community.naturalcapitalproject.org
  • +
  • Correcting an issue with the Coastal Blue Carbon preprocessor where using misaligned landcover rasters would cause an exception to be raised.
  • +
  • Correcting an issue with RouteDEM where runs of the tool with Flow Direction enabled would cause the tool to crash if n_workers > 0.
  • +
  • Correcting an issue with Habitat Quality's error checking where nodata values in landcover rasters were not being taken into account.
  • +
  • Valuation is now an optional component of the InVEST Scenic Quality model.
  • +
  • Fixing a bug in the percentiles algorithm used by Scenic Quality that would result in incorrect visual quality outputs.
  • +
  • Carbon Model and Crop Production models no longer crash if user-input rasters do not have a nodata value defined. In this case these models treat all pixel values as valid data.
  • +
  • Adding bitbucket pipelines and AppVeyor build configurations.
  • +
  • Refactoring Recreation Model client to use taskgraph and the latest pygeoprocessing. Avoided re-computation from taskgraph means that successive model runs with the same AOI and gridding option can re-use PUD results and avoid server communication entirely. Successive runs with the same predictor data will re-use intermediate geoprocessing results. Multiprocessing offered by taskgraph means server-side PUD calculations and client-side predictor data processing can happen in parallel. Some output filenames have changed.
  • +
  • Upgrading to SDR to use new PyGeoprocessing multiflow routing, DEM pit filling, contiguous stream extraction, and TaskGraph integration. This also includes a new TaskGraph feature that avoids recomputation by copying results from previous runs so long as the expected result would be identical. To use this feature, users must execute successive runs of SDR in the same workspace but use a different file suffix. This is useful when users need to do a parameter study or run scenarios with otherwise minor changes to inputs.
  • +
  • Refactoring Habitat Risk Assessment (HRA) Model to use TaskGraph >= 0.8.2 and Pygeoprocessing >= 1.6.1. The HRA Proprocessor is removed and its previous functionality was simplified and merged into the HRA model itself. The model will no longer generate HTML plots and tables.
  • +
  • Adding a software update notification button, dialog, and a link to the download page on the User Interface when a new InVEST version is available.
  • +
  • Migrating the subversion sample and test data repositories to Git LFS repositories on BitBucket. Update the repository URL and fetch commands on Makefile accordingly.
  • +
  • Fixing a bug in Habitat Quality UI where the absence of the required half_saturation_constant variable did not raise an exception.
  • +
  • Adding encoding='utf-8-sig' to pandas.read_csv() to support utils.build_lookup_from_csv() to read CSV files encoded with UTF-8 BOM (byte-order mark) properly.
  • +
+
+
+

3.6.0 (2019-01-30)

+
    +
  • Correcting an issue with the InVEST Carbon Storage and Sequestration model where filepaths containing non-ASCII characters would cause the model's report generation to crash. The output report is now a UTF-8 document.
  • +
  • Refactoring RouteDEM to use taskgraph and the latest pygeoprocessing (>=1.5.0). RouteDEM now fills hydrological sinks and users have the option to use either of the D8 or Multiple Flow Direction (MFD) routing algorithms.
  • +
  • Adding a new input to the InVEST Settings window to allow users to customize the value that should be used for the n_workers parameter in taskgraph-enabled models. This change involves removing the "Number of Parallel Workers" input from the model inputs pane for some models in favor of this new location. The default value for this setting is -1, indicating synchronous (non-threaded, non-multiprocessing) execution of tasks.
  • +
  • Removing Scenario Generator: Rule-based model.
  • +
  • Fixing a bug in Hydropower model where watershed aggregations would be incorrect if a watershed is partially covering nodata raster values. Nodata values are now ignored in zonal statistics. Numerical results change very slightly in the case where a watershed only includes a few nodata pixels.
  • +
  • Adding TaskGraph functionality to GLOBIO model.
  • +
  • Adding some TaskGraph functionality to Scenario Generator: Proximity.
  • +
  • Fixing an issue with the InVEST Fisheries model that would prevent the model from batch-processing a directory of population tables. The model will now process these files as expected.
  • +
  • Reimplementing Crop Production models using taskgraph.
  • +
  • Fixing an issue with Crop Production Regression's result_table.csv where the 'production_modeled' and '<nutrient>_modeled' values calculated for each crop were done so using the same crop raster (e.g. wheat, soybean, and barley values were all based on soybean data).
  • +
  • Hydropower subwatershed results now include all the same metrics as the watershed results, with the exception of economic valuation metrics.
  • +
  • Reimplementing the Hydropower model using taskgraph.
  • +
  • Reimplementing the Carbon model using taskgraph.
  • +
  • Fixing an issue with Coastal Blue Carbon validation to allow column names to ignore case.
  • +
  • Updating core carbon forest edge regression data coefficient to drop impossible negative coefficients.
  • +
  • Fixing an issue with the Scenario Generator: Proximity model that would raise an exception if no AOI were passed in even though the AOI is optional.
  • +
  • Removing Overlap Analysis and Overlap Analysis: Management Zones.
  • +
  • Removing Habitat Suitability.
  • +
  • Added comprehensive error checking to hydropower model to test for the VERY common errors of missing biophysical, demand, and valuation coefficients in their respective tables.
  • +
  • Fixing an issue with Hydropower Water Yield ("Annual Water Yield") where valuation would never be triggered when running the model through the User Interface. And a related issue where the model would crash if a valuation table was provided but a demand table was not. The UI no longer validates that config.
  • +
  • Fixing an issue with how logging is captured when a model is run through the InVEST User Interface. Now, logging from any thread started by the executor thread will be written to the log file, which we expect to aid in debugging.
  • +
  • Fixing an issue with Scenic Quality where viewpoints outside of the AOI were not being properly excluded. Viewpoints are now excluded correctly.
  • +
  • The crop production model has been refactored to drop the "aggregate ID" concept when summarizing results across an aggregate polygon. The model now uses the polygon FIDs internally and externally when producing the result summary table.
  • +
  • Correcting the rating instructions in the criteria rating instructions on how the data quality (DQ) and weight should be rated in the HRA Preprocessor. A DQ score of 1 should represent better data quality whereas the score of 3 is worse data quality. A weight score of 1 is more important, whereas that of 3 is less important.
  • +
  • Fixing a case where a zero discount rate and rate of change in the carbon model would cause a divide by zero error.
  • +
+
+
+

3.5.0 (2018-08-14)

+
    +
  • Bumped pygeoprocessing requirement to pygeoprocessing>=1.2.3.
  • +
  • Bumped taskgraph requirement to taskgraph>=0.6.1.
  • +
  • Reimplemented the InVEST Scenic Quality model. This new version removes the 'population' and 'overlap' postprocessing steps, updates the available valuation functions and greatly improves the runtime and memory-efficiency of the model. See the InVEST User's Guide chapter for more information.
  • +
  • Updated Recreation server's database to include metadata from photos taken from 2005-2017 (previous range was 2005-2014). The new range is reflected in the UI.
  • +
  • Fixed an issue with the InVEST binary build where binaries on Windows would crash with an error saying Python27.dll could not be loaded.
  • +
  • Fixed an issue in the Rule-Based Scenario Generator UI where vector column names from override and constraint layers were not being loaded. This bug caused the field 'UNKNOWN' to be passed to the model, causing an error.
  • +
  • Fixed an issue with the InVEST UI (all models), where attempting to drag-and-drop a directory onto a model input would cause the application to crash.
  • +
  • Coastal Vulnerability UI now specifies a number of reasonable defaults for some numeric inputs.
  • +
  • Fixed an issue with the Fisheries UI where alpha and beta parameter inputs were incorrectly disabled for the Ricker recruitment function.
  • +
  • InVEST now uses a Makefile to automate the build processes. GNU Make is required to use the Makefile. See README.rst for instructions on building InVEST. This replaces the old pavement.py build entrypoint, which has been removed.
  • +
  • Fixed an issue with the InVEST UI (all models), where attempting to drag-and-drop a directory onto a model input would cause the application to crash.
  • +
  • Fixed an issue with Forest Carbon Edge Effect where the UI layer was always causing the model to run with only the aboveground carbon pool
  • +
  • Added functionality to the InVEST UI so that Dropdown inputs can now map dropdown values to different output values.
  • +
  • Fixed an issue in the Crop Production Percentile model that would treat the optional AOI vector field as a filename and crash on a run if it were empty.
  • +
  • Fixing an issue in the Pollination Model that would cause occasional crashes due to a missing dependent task; it had previously been patched by setting taskgraph to operate in single thread mode. This restores multithreading in the pollination model.
  • +
  • Fixed an issue in the water yield / hydropower model that would skip calculation of water demand tables when "water scarcity" was enabled.
  • +
  • Fixed an issue in the model data of the crop production model where some crops were using incorrect climate bin rasters. Since the error was in the data and not the code, users will need to download the most recent version of InVEST's crop model data during the installation step to get the fix.
  • +
+
+
+

3.4.4 (2018-03-26)

+
    +
  • InVEST now requires GDAL 2.0.0 and has been tested up to GDAL 2.2.3. Any API users of InVEST will need to use GDAL version >= 2.0. When upgrading GDAL we noticed slight numerical differences in our test suite in both numerical raster differences, geometry transforms, and occasionally a single pixel difference when using gdal.RasterizeLayer. Each of these differences in the InVEST test suite is within a reasonable numerical tolerance and we have updated our regression test suite appropriately. Users comparing runs between previous versions of InVEST may also notice reasonable numerical differences between runs.
  • +
  • Added a UI keyboard shortcut for showing documentation. On Mac OSX, this will be Command-?. On Windows, GNOME and KDE, this will be F1.
  • +
  • Patching an issue in NDR that was using the nitrogen subsurface retention efficiency for both nitrogen and phosphorous.
  • +
  • Fixed an issue with the Seasonal Water Yield model that incorrectly required a rain events table when the climate zone mode was in use.
  • +
  • Fixed a broken link to local and online user documentation from the Seasonal Water Yield model from the model's user interface.
  • +
+
+
+

3.4.3 (2018-03-26)

+
    +
  • Fixed a critical issue in the carbon model UI that would incorrectly state the user needed a "REDD Priority Raster" when none was required.
  • +
  • Fixed an issue in annual water yield model that required subwatersheds even though it is an optional field.
  • +
  • Fixed an issue in wind energy UI that was incorrectly validating most of the inputs.
  • +
+
+
+

3.4.2 (2017-12-15)

+
    +
  • Fixed a cross-platform issue with the UI where logfiles could not be dropped onto UI windows.
  • +
  • Model arguments loaded from logfiles are now cast to their correct literal value. This addresses an issue where some models containing boolean inputs could not have their parameters loaded from logfiles.
  • +
  • Fixed an issue where the Pollination Model's UI required a farm polygon. It should have been optional and now it is.
  • +
  • Fixing an issue with the documentation and forums links on the InVEST model windows. The links now correctly link to the documentation page or forums as needed.
  • +
  • Fixing an issue with the FileSystemRunDialog where pressing the 'X' button in the corner of the window would close the window, but not reset its state. The window's state is now reset whenever the window is closed (and the window cannot be closed when the model is running)
  • +
+
+
+

3.4.1 (2017-12-11)

+
    +
  • In the Coastal Blue Carbon model, the interest_rate parameter has been renamed to inflation_rate.
  • +
  • Fixed issues with sample parameter sets for InVEST Habitat Quality, Habitat Risk Assessment, Coastal Blue Carbon, and Coastal Blue Carbon Preprocessors. All sample parameter sets now have the correct paths to the model's input files, and correctly note the name of the model that they apply to.
  • +
  • Added better error checking to the SDR model for missing ws_id and invalid ws_id values such as None or some non-integer value. Also added tests for the SDR validation module.
  • +
+
+
+

3.4.0 (2017-12-03)

+
    +
  • Fixed an issue with most InVEST models where the suffix was not being reflected in the output filenames. This was due to a bug in the InVEST UI, where the suffix args key was assumed to be 'suffix'. Instances of InVESTModel now accept a keyword argument to defined the suffix args key.
  • +
  • Fixed an issue/bug in Seasonal Water Yield that would occur when a user provided a datastack that had nodata values overlapping with valid DEM locations. Previously this would generate an NaN for various biophysical values at that pixel and cascade it downslope. Now any question of nodata on a valid DEM pixel is treated as "0". This will make serious visual artifacts on the output, but should help users pinpoint the source of bad data rather than crash.
  • +
  • Refactored all but routing components of SDR to use PyGeoprocessing 0.5.0 and laid a consistent raster floating point type of 'float32'. This will cause numerically insignificant differences between older versions of SDR and this one. But differences are well within the tolerance of the overall error of the model and expected error rate of data. Advantages are smaller disk footprint per run, cleaner and more maintainable design, and a slight performance increase.
  • +
  • Bug fixed in SDR that would align the output raster stack to match with the landcover pixel stack even though the rest of the rasters are scaled and clipped to the DEM.
  • +
  • When loading parameters from a datastack, parameter set or logfile, the UI will check that the model that created the file being loaded matches the name of the model that is currently running. If there is a mismatch, a dialog is presented for the user to confirm or cancel the loading of parameters. Logfiles from IUI (which do not have clearly-recorded modelname or InVEST version information) can still have their arguments parsed, but the resulting model name and InVEST version will be set to "UNKNOWN".
  • +
  • Data Stack files (*.invest.json, *.invest.tar.gz) can now be dragged and dropped on an InVEST model window, which will prompt the UI to load that parameter set.
  • +
  • Spatial inputs to Coastal Blue Carbon are now aligned as part of the model. This resolves a longstanding issue with the model where inputs would need to perfectly overlap (even down to pixel indices), or else the model would yield strange results.
  • +
  • The InVEST UI now contains a submenu for opening a recently-opened datastack. This submenu is automatically populated with the 10 most recently-opened datastacks for the current model.
  • +
  • Removed vendored natcap.invest.dbfpy subpackage.
  • +
  • Removed deprecated natcap.invest.fileio module.
  • +
  • Removed natcap.invest.iui UI subpackage in favor of a new UI framework found at natcap.invest.ui. This new UI features a greatly improved API, good test coverage, support for Qt4 and Qt5, and includes updates to all InVEST models to support validation of model arguments from a python script, independent of the UI.
  • +
  • Updated core model of seasonal water yield to allow for negative L_avail.
  • +
  • Updated RouteDEM to allow for file suffixes, finer control over what DEM routing algorithms to run, and removal of the multiple stepped stream threshold classification.
  • +
  • Redesign/refactor of pollination model. Long term bugs in the model are resolved, managed pollinators added, and many simplifications to the end user's experience. The updated user's guide chapter is available here: http://data.naturalcapitalproject.org/nightly-build/invest-users-guide/html/croppollination.html
  • +
  • Scenario Generator - Rule Based now has an optional input to define a seed. This input is used to seed the random shuffling of parcels that have equal priorities.
  • +
  • InVEST on mac is now distributed as a single application bundle, allowing InVEST to run as expected on mac OSX Sierra. Individual models are selected and launched from a new launcher window.
  • +
  • The InVEST CLI now has a GUI model launcher: $ invest launcher
  • +
  • Updated the Coastal Blue Carbon model to improve handling of blank lines in input CSV tables and improve memory efficiency of the current implementation.
  • +
  • Improved the readability of a cryptic error message in Coastal Vulnerability that is normally raised when the depth threshold is too high or the exposure proportion is too low to detect any shoreline segments.
  • +
  • Adding InVEST HTML documentation to the Mac disk image distribution.
  • +
  • Upgrading dependency of PyGeoprocessing to 0.3.3. This fixes a memory leak associated with any model that aggregates rasters over complicated overlapping polygons.
  • +
  • Adding sample data to Blue Carbon model that were missing.
  • +
  • Deprecating the InVEST Marine Water Quality model. This also removes InVEST's dependancy on the pyamg package which has been removed from REQUIREMENTS.TXT.
  • +
  • Deprecating the ArcGIS-based Coastal Protection model and ArcGIS-based data-preprocessing scripts. The toolbox and scripts may still be found at https://bitbucket.org/natcap/invest.arcgis.
  • +
  • Fixing an issue in the carbon edge effect model that caused output values in the shapefile to be rounded to the nearest integer.
  • +
  • Fixing issue in SDR model that would occasionally cause users to see errors about field widths in the output shapefile generation.
  • +
  • Updated the erodibility sample raster that ships with InVEST for the SDR model. The old version was in US units, in this version we convert to SI units as the model requires, and clipped the raster to the extents of the other stack to save disk space.
  • +
+
+
+

3.3.3 (2017-02-06)

+
    +
  • Fixed an issue in the UI where the carbon model wouldn't accept negative numbers in the price increase of carbon.
  • +
  • RouteDEM no longer produces a "tiled_dem.tif" file since that functionality is being deprecated in PyGeoprocessing.
  • +
  • Fixing an issue in SDR where the optional drainage layer would not be used in most of the SDR biophysical calculations.
  • +
  • Refactoring so water yield pixels with Kc and et0 equal to be 0 now yields a 0.0 value of water yield on that pixel rather than nodata.
  • +
  • Light optimization refactor of wind energy model that improves runtimes in some cases by a factor of 2-3.
  • +
  • Performance optimizations to HRA that improve runtimes by approximately 30%.
  • +
  • Fixed a broken UI link to Seasonal Water Yield's user's guide.
  • +
  • Fixed an issue with DelineateIT that caused ArcGIS users to see both the watershed and inverse watershed polygons when viewing the output of the tool.
  • +
  • Upgrading dependency to PyGeoprocessing 0.3.2.
  • +
  • Fixed an issue with SDR that caused the LS factor to be an order of magnitue too high in areas where the slope was greater than 9%. In our sample case this caused sediment export estimates to be about 6% too high, but in cases where analyses are run over steep slopes the error would have been greater.
  • +
  • paver check now warns if the PYTHONHOME environment variable is set.
  • +
  • API docs now correctly reflect installation steps needed for python development headers on linux.
  • +
  • Fixed a side effect in the InVEST user interface that would cause tempfile.tempdir to be set and then not be reset after a model run is finished.
  • +
  • The InVEST user interface will now record GDAL/OGR log messages in the log messages window and in the logfile written to the workspace.
  • +
  • Updated branding and usability of the InVEST installer for Windows, and the Mac Disk Image (.dmg).
  • +
+
+
+

3.3.2 (2016-10-17)

+
    +
  • Partial test coverage for HRA model.
  • +
  • Full test coverage for Overlap Analysis model.
  • +
  • Full test coverage for Finfish Aquaculture.
  • +
  • Full test coverage for DelineateIT.
  • +
  • Full test coverage for RouteDEM.
  • +
  • Fixed an issue in Habitat Quality where an error in the sample table or malformed threat raster names would display a confusing message to the user.
  • +
  • Full test coverage for scenario generator proximity model.
  • +
  • Patching an issue in seasonal water yield that causes an int overflow error if the user provides a floating point landcover map and the nodata value is outside of the range of an int64.
  • +
  • Full test coverage for the fisheries model.
  • +
  • Patched an issue that would cause the Seasonal Water Edge model to crash when the curve number was 100.
  • +
  • Patching a critical issue with forest carbon edge that would give incorrect results for edge distance effects.
  • +
  • Patching a minor issue with forest carbon edge that would cause the model to crash if only one interpolation point were selected.
  • +
  • Full test coverage for pollination model.
  • +
  • Removed "farms aggregation" functionality from the InVEST pollination model.
  • +
  • Full test coverage for the marine water quality model.
  • +
  • Full test coverage for GLOBIO model.
  • +
  • Full test coverage for carbon forest edge model.
  • +
  • Upgraded SciPy dependancy to 0.16.1.
  • +
  • Patched bug in NDR that would cause a phosphorus density to be reported per pixel rather than total amount of phosporous in a pixel.
  • +
  • Corrected an issue with the uses of buffers in the euclidean risk function of Habitat Risk Assessment. (issue #3564)
  • +
  • Complete code coverage tests for Habitat Quality model.
  • +
  • Corrected an issue with the Fisheries_Inputs.csv sample table used by Overlap Analysis. (issue #3548)
  • +
  • Major modifications to Terrestrial Carbon model to include removing the harvested wood product pool, uncertainty analysis, and updated efficient raster calculations for performance.
  • +
  • Fixed an issue in GLOBIO that would cause model runs to crash if the AOI marked as optional was not present.
  • +
  • Removed the deprecated and incomplete Nearshore Wave and Erosion model (natcap.invest.nearshore_wave_and_erosion).
  • +
  • Removed the deprecated Timber model (natcap.invest.timber).
  • +
  • Fixed an issue where seasonal water yield would raise a divide by zero error if a watershed polygon didn't cover a valid data region. Now sets aggregation quantity to zero and reports a warning in the log.
  • +
  • natcap.invest.utils.build_file_registry now raises a ValueError if a path is not a string or list of strings.
  • +
  • Fixed issues in NDR that would indicate invalid values were being processed during runtimes by skipping the invalid calculations in the first place rather than calculating them and discarding after the fact.
  • +
  • Complete code coverage tests for NDR model.
  • +
  • Minor (~10% speedup) performance improvements to NDR.
  • +
  • Added functionality to recreation model so that the monthly_table.csv file now receives a file suffix if one is provided by the user.
  • +
  • Fixed an issue in SDR where the m exponent was calculated incorrectly in many situations resulting in an error of about 1% in total export.
  • +
  • Fixed an issue in SDR that reported runtime overflow errors during normal processing even though the model completed without other errors.
  • +
+
+
+

3.3.1 (2016-06-13)

+
    +
  • Refactored API documentation for readability, organization by relevant topics, and to allow docs to build on invest.readthedocs.io,
  • +
  • Installation of natcap.invest now requires natcap.versioner. If this is not available on the system at runtime, setuptools will make it available at runtime.
  • +
  • InVEST Windows installer now includes HISTORY.rst as the changelog instead of the old InVEST_Updates_<version> files.
  • +
  • +
    +
    Habitat suitability model is generalized and released as an API only accessible model. It can be found at natcap.invest.habitat_suitability.execute. This model replaces the oyster habitat suitability model.
    +
    +
      +
    • The refactor of this model requires an upgrade to numpy >= 1.11.0.
    • +
    +
    +
    +
  • +
  • Fixed a crash in the InVEST CLI where calling invest without a parameter would raise an exception on linux-based systems. (Issue #3528)
  • +
  • Patched an issue in Seasonal Water Yield model where a nodata value in the landcover map that was equal to MAX_INT would cause an overflow error/crash.
  • +
  • InVEST NSIS installer will now optionally install the Microsoft Visual C++ 2008 redistributable on Windows 7 or earlier. This addresses a known issue on Windows 7 systems when importing GDAL binaries (Issue #3515). Users opting to install this redistributable agree to abide by the terms and conditions therein.
  • +
  • Removed the deprecated subpackage natcap.invest.optimization.
  • +
  • Updated the InVEST license to legally define the Natural Capital Project.
  • +
  • Corrected an issue in Coastal Vulnerability where an output shapefile was being recreated for each row, and where field values were not being stored correctly.
  • +
  • Updated Scenario Generator model to add basic testing, file registry support, PEP8 and PEP257 compliance, and to fix several bugs.
  • +
  • Updated Crop Production model to add a simplified UI, faster runtime, and more testing.
  • +
+
+
+

3.3.0 (2016-03-14)

+
    +
  • Refactored Wind Energy model to use a CSV input for wind data instead of a Binary file.
  • +
  • +
    +
    Redesigned InVEST recreation model for a single input streamlined interface, advanced analytics, and refactored outputs. While the model is still based on "photo user days" old model runs are not backward compatable with the new model or interface. See the Recreation Model user's guide chapter for details.
    +
    +
      +
    • The refactor of this model requires an upgrade to GDAL >=1.11.0 <2.0 and numpy >= 1.10.2.
    • +
    +
    +
    +
  • +
  • Removed nutrient retention (water purification) model from InVEST suite and replaced it with the nutrient delivery ratio (NDR) model. NDR has been available in development relseases, but has now officially been added to the set of Windows Start Menu models and the "under development" tag in its users guide has been removed. See the InVEST user's guide for details between the differences and advantages of NDR over the old nutrient model.
  • +
  • Modified NDR by adding a required "Runoff Proxy" raster to the inputs. This allows the model to vary the relative intensity of nutrient runoff based on varying precipitation variability.
  • +
  • Fixed a bug in the Area Change rule of the Rule-Based Scenario Generator, where units were being converted incorrectly. (Issue #3472) Thanks to Fosco Vesely for this fix.
  • +
  • InVEST Seasonal Water Yield model released.
  • +
  • InVEST Forest Carbon Edge Effect model released.
  • +
  • InVEST Scenario Generator: Proximity Based model released and renamed the previous "Scenario Generator" to "Scenario Generator: Rule Based".
  • +
  • Implemented a blockwise exponential decay kernel generation function, which is now used in the Pollination and Habitat Quality models.
  • +
  • GLOBIO now uses an intensification parameter and not a map to average all agriculture across the GLOBIO 8 and 9 classes.
  • +
  • GLOBIO outputs modified so core outputs are in workspace and intermediate outputs are in a subdirectory called 'intermediate_outputs'.
  • +
  • Fixed a crash with the NDR model that could occur if the DEM and landcover maps were different resolutions.
  • +
  • Refactored all the InVEST model user interfaces so that Workspace defaults to the user's home "Documents" directory.
  • +
  • Fixed an HRA bug where stessors with a buffer of zero were being buffered by 1 pixel
  • +
  • HRA enhancement which creates a common raster to burn all input shapefiles onto, ensuring consistent alignment.
  • +
  • Fixed an issue in SDR model where a landcover map that was smaller than the DEM would create extraneous "0" valued cells.
  • +
  • New HRA feature which allows for "NA" values to be entered into the "Ratings" column for a habitat / stressor pair in the Criteria Ratings CSV. If ALL ratings are set to NA, the habitat / stressor will be treated as having no interaction. This means in the model, that there will be no overlap between the two sources. All rows parameters with an NA rating will not be used in calculating results.
  • +
  • Refactored Coastal Blue Carbon model for greater speed, maintainability and clearer documentation.
  • +
  • Habitat Quality bug fix when given land cover rasters with different pixel sizes than threat rasters. Model would use the wrong pixel distance for the convolution kernel.
  • +
  • Light refactor of Timber model. Now using CSV input attribute file instead of DBF file.
  • +
  • Fixed clipping bug in Wave Energy model that was not properly clipping polygons correctly. Found when using global data.
  • +
  • +
    +
    Made the following changes / updates to the coastal vulnerability model:
    +
    +
      +
    • Fixed a bug in the model where the geomorphology ranks were not always being used correctly.
    • +
    • Removed the HTML summary results output and replaced with a link to a dashboard that helps visualize and interpret CV results.
    • +
    • Added a point shapefile output: 'outputs/coastal_exposure.shp' that is a shapefile representation of the corresponding CSV table.
    • +
    • The model UI now requires the 'Relief' input. No longer optional.
    • +
    • CSV outputs and Shapefile outputs based on rasters now have x, y coorinates of the center of the pixel instead of top left of the pixel.
    • +
    +
    +
    +
  • +
  • Turning setuptools' zip_safe to False for consistency across the Natcap Namespace.
  • +
  • GLOBIO no longer requires user to specify a keyfield in the AOI.
  • +
  • New feature to GLOBIO to summarize MSA by AOI.
  • +
  • New feature to GLOBIO to use a user defined MSA parameter table to do the MSA thresholds for infrastructure, connectivity, and landuse type
  • +
  • Documentation to the GLOBIO code base including the large docstring for 'execute'.
  • +
+
+
+

3.2.0 (2015-05-31)

+

InVEST 3.2.0 is a major release with the addition of several experimental models and tools as well as an upgrade to the PyGeoprocessing core:

+
    +
  • Upgrade to PyGeoprocessing v0.3.0a1 for miscelaneous performance improvements to InVEST's core geoprocessing routines.
  • +
  • An alpha unstable build of the InVEST crop production model is released with partial documentation and sample data.
  • +
  • A beta build of the InVEST fisheries model is released with documentation and sample data.
  • +
  • An alpha unstable build of the nutrient delivery ratio (NDR) model is available directly under InVEST's instalation directory at invest-x86/invest_ndr.exe; eventually this model will replace InVEST's current "Nutrient" model. It is currently undocumented and unsupported but inputs are similar to that of InVEST's SDR model.
  • +
  • An alpha unstable build of InVEST's implementation of GLOBIO is available directly under InVEST's instalation directory at invest-x86/invest_globio.exe. It is currently undocumented but sample data are provided.
  • +
  • DelinateIT, a watershed delination tool based on PyGeoprocessing's d-infinity flow algorithm is released as a standalone tool in the InVEST repository with documentation and sample data.
  • +
  • Miscelaneous performance patches and bug fixes.
  • +
+
+
+

3.1.3 (2015-04-23)

+

InVEST 3.1.3 is a hotfix release patching a memory blocking issue resolved in PyGeoprocessing version 0.2.1. Users might have experienced slow runtimes on SDR or other routed models.

+
+
+

3.1.2 (2015-04-15)

+

InVEST 3.1.2 is a minor release patching issues mostly related to the freshwater routing models and signed GDAL Byte datasets.

+
    +
  • Patching an issue where some projections were not regognized and InVEST reported an UnprojectedError.
  • +
  • Updates to logging that make it easier to capture logging messages when scripting InVEST.
  • +
  • Shortened water yield user interface height so it doesn't waste whitespace.
  • +
  • Update PyGeoprocessing dependency to version 0.2.0.
  • +
  • Fixed an InVEST wide issue related to bugs stemming from the use of signed byte raster inputs that resulted in nonsensical outputs or KeyErrors.
  • +
  • Minor performance updates to carbon model.
  • +
  • Fixed an issue where DEMS with 32 bit ints and INT_MAX as the nodata value nodata value incorrectly treated the nodata value in the raster as a very large DEM value ultimately resulting in rasters that did not drain correctly and empty flow accumulation rasters.
  • +
  • Fixed an issue where some reservoirs whose edges were clipped to the edge of the watershed created large plateaus with no drain except off the edge of the defined raster. Added a second pass in the plateau drainage algorithm to test for these cases and drains them to an adjacent nodata area if they occur.
  • +
  • Fixed an issue in the Fisheries model where the Results Suffix input was invariably initializing to an empty string.
  • +
  • Fixed an issue in the Blue Carbon model that prevented the report from being generated in the outputs file.
  • +
+
+
+

3.1.1 (2015-03-13)

+

InVEST 3.1.1 is a major performance and memory bug patch to the InVEST toolsuite. We recommend all users upgrade to this version.

+
    +
  • Fixed an issue surrounding reports of SDR or Nutrient model outputs of zero values, nodata holes, excessive runtimes, or out of memory errors. Some of those problems happened to be related to interesting DEMs that would break the flat drainage algorithm we have inside RouteDEM that adjusted the heights of those regions to drain away from higher edges and toward lower edges, and then pass the height adjusted dem to the InVEST model to do all its model specific calculations. Unfortunately this solution was not amenable to some degenerate DEM cases and we have now adjusted the algorithm to treat each plateau in the DEM as its own separate region that is processed independently from the other regions. This decreases memory use so we never effectively run out of memory at a minor hit to overall runtime. We also now adjust the flow direction directly instead of adjust the dem itself. This saves us from having to modify the DEM and potentially get it into a state where a drained plateau would be higher than its original pixel neighbors that used to drain into it.
  • +
+

There are side effects that result in sometimes large changes to un calibrated runs of SDR or nutrient. These are related to slightly different flow directions across the landscape and a bug fix on the distance to stream calculation.

+
    +
  • InVEST geoprocessing now uses the PyGeoprocessing package (v0.1.4) rather than the built in functionality that used to be in InVEST. This will not affect end users of InVEST but may be of interest to users who script InVEST calls who want a standalone Python processing package for raster stack math and hydrological routing. The project is hosted at https://bitbucket.org/richpsharp/pygeoprocessing.
  • +
  • Fixed an marine water quality issue where users could input AOIs that were unprojected, but output pixel sizes were specified in meters. Really the output pixel size should be in the units of the polygon and are now specified as such. Additionally an exception is raised if the pixel size is too small to generate a numerical solution that is no longer a deep scipy error.
  • +
  • Added a suffix parameter to the timber and marine water quality models that append a user defined string to the output files; consistent with most of the other InVEST models.
  • +
  • Fixed a user interface issue where sometimes the InVEST model run would not open a windows explorer to the user's workspace. Instead it would open to C:User[..]My Documents. This would often happen if there were spaces in the the workspace name or "/" characters in the path.
  • +
  • Fixed an error across all InVEST models where a specific combination of rasters of different cell sizes and alignments and unsigned data types could create errors in internal interpolation of the raster stacks. Often these would appear as 'KeyError: 0' across a variety of contexts. Usually the '0' was an erroneous value introduced by a faulty interpolation scheme.
  • +
  • Fixed a MemoryError that could occur in the pollination and habitat quality models when the the base landcover map was large and the biophysical properties table allowed the effect to be on the order of that map. Now can use any raster or range values with only a minor hit to runtime performance.
  • +
  • Fixed a serious bug in the plateau resolution algorithm that occurred on DEMs with large plateau areas greater than 10x10 in size. The underlying 32 bit floating point value used to record small height offsets did not have a large enough precision to differentiate between some offsets thus creating an undefined flow direction and holes in the flow accumulation algorithm.
  • +
  • Minor performance improvements in the routing core, in some cases decreasing runtimes by 30%.
  • +
  • Fixed a minor issue in DEM resolution that occurred when a perfect plateau was encountered. Rather that offset the height so the plateau would drain, it kept the plateau at the original height. This occurred because the uphill offset was nonexistent so the algorithm assumed no plateau resolution was needed. Perfect plateaus now drain correctly. In practice this kind of DEM was encountered in areas with large bodies of water where the remote sensing algorithm would classify the center of a lake 1 meter higher than the rest of the lake.
  • +
  • Fixed a serious routing issue where divergent flow directions were not getting accumulated 50% of the time. Related to a division speed optimization that fell back on C-style modulus which differs from Python.
  • +
  • InVEST SDR model thresholded slopes in terms of radians, not percent thus clipping the slope tightly between 0.001 and 1%. The model now only has a lower threshold of 0.00005% for the IC_0 factor, and no other thresholds. We believe this was an artifact left over from an earlier design of the model.
  • +
  • Fixed a potential memory inefficiency in Wave Energy Model when computing the percentile rasters. Implemented a new memory efficient percentile algorithm and updated the outputs to reflect the new open source framework of the model. Now outputting csv files that describe the ranges and meaning of the percentile raster outputs.
  • +
  • Fixed a bug in Habitat Quality where the future output "quality_out_f.tif" was not reflecting the habitat value given in the sensitivity table for the specified landcover types.
  • +
+
+
+

3.1.0 (2014-11-19)

+

InVEST 3.1.0 (http://www.naturalcapitalproject.org/download.html) is a major software and science milestone that includes an overhauled sedimentation model, long awaited fixes to exponential decay routines in habitat quality and pollination, and a massive update to the underlying hydrological routing routines. The updated sediment model, called SDR (sediment delivery ratio), is part of our continuing effort to improve the science and capabilities of the InVEST tool suite. The SDR model inputs are backwards comparable with the InVEST 3.0.1 sediment model with two additional global calibration parameters and removed the need for the retention efficiency parameter in the biophysical table; most users can run SDR directly with the data they have prepared for previous versions. The biophysical differences between the models are described in a section within the SDR user's guide and represent a superior representation of the hydrological connectivity of the watershed, biophysical parameters that are independent of cell size, and a more accurate representation of sediment retention on the landscape. Other InVEST improvements to include standard bug fixes, performance improvements, and usability features which in part are described below:

+
    +
  • InVEST Sediment Model has been replaced with the InVEST Sediment Delivery Ratio model. See the SDR user's guide chapter for the difference between the two.
  • +
  • Fixed an issue in the pollination model where the exponential decay function decreased too quickly.
  • +
  • Fixed an issue in the habitat quality model where the exponential decay function decreased too quickly and added back linear decay as an option.
  • +
  • Fixed an InVEST wide issue where some input rasters that were signed bytes did not correctly map to their negative nodata values.
  • +
  • Hydropower input rasters have been normalized to the LULC size so sampling error is the same for all the input watersheds.
  • +
  • Adding a check to make sure that input biophysical parameters to the water yield model do not exceed invalid scientific ranges.
  • +
  • Added a check on nutrient retention in case the upstream water yield was less than 1 so that the log value did not go negative. In that case we clamp upstream water yield to 0.
  • +
  • A KeyError issue in hydropower was resolved that occurred when the input rasters were at such a coarse resolution that at least one pixel was completely contained in each watershed. Now a value of -9999 will be reported for watersheds that don't contain any valid data.
  • +
  • An early version of the monthly water yield model that was erroneously included in was in the installer; it was removed in this version.
  • +
  • Python scripts necessary for running the ArcGIS version of Coastal Protection were missing. They've since been added back to the distribution.
  • +
  • Raster calculations are now processed by raster block sizes. Improvements in raster reads and writes.
  • +
  • Fixed an issue in the routing core where some wide DEMs would cause out of memory errors.
  • +
  • Scenario generator marked as stable.
  • +
  • Fixed bug in HRA where raster extents of shapefiles were not properly encapsulating the whole AOI.
  • +
  • Fixed bug in HRA where any number of habitats over 4 would compress the output plots. Now extends the figure so that all plots are correctly scaled.
  • +
  • Fixed a bug in HRA where the AOI attribute 'name' could not be an int. Should now accept any type.
  • +
  • Fixed bug in HRA which re-wrote the labels if it was run immediately without closing the UI.
  • +
  • Fixed nodata masking bug in Water Yield when raster extents were less than that covered by the watershed.
  • +
  • Removed hydropower calibration parameter form water yield model.
  • +
  • Models that had suffixes used to only allow alphanumeric characters. Now all suffix types are allowed.
  • +
  • A bug in the core platform that would occasionally cause routing errors on irregularly pixel sized rasters was fixed. This often had the effect that the user would see broken streams and/or nodata values scattered through sediment or nutrient results.
  • +
  • +
    +
    Wind Energy:
    +
    +
      +
    • Added new framework for valuation component. Can now input a yearly price table that spans the lifetime of the wind farm. Also if no price table is made, can specify a price for energy and an annual rate of change.
    • +
    • Added new memory efficient distance transform functionality
    • +
    • Added ability to leave out 'landing points' in 'grid connection points' input. If not landing points are found, it will calculate wind farm directly to grid point distances
    • +
    +
    +
    +
  • +
  • Error message added in Wave Energy if clip shape has no intersection
  • +
  • Fixed an issue where the data type of the nodata value in a raster might be different than the values in the raster. This was common in the case of 64 bit floating point values as nodata when the underlying raster was 32 bit. Now nodata values are cast to the underlying types which improves the reliability of many of the InVEST models.
  • +
+
+
+

3.0.1 (2014-05-19)

+
    +
  • Blue Carbon model released.
  • +
  • HRA UI now properly reflects that the Resolution of Analysis is in meters, not meters squared, and thus will be applied as a side length for a raster pixel.
  • +
  • HRA now accepts CSVs for ratings scoring that are semicolon separated as well as comma separated.
  • +
  • Fixed a minor bug in InVEST's geoprocessing aggregate core that now consistently outputs correct zonal stats from the underlying pixel level hydro outputs which affects the water yield, sediment, and nutrient models.
  • +
  • Added compression to InVEST output geotiff files. In most cases this reduces output disk usage by a factor of 5.
  • +
  • Fixed an issue where CSVs in the sediment model weren't open in universal line read mode.
  • +
  • Fixed an issue where approximating whether pixel edges were the same size was not doing an approximately equal function.
  • +
  • Fixed an issue that made the CV model crash when the coastline computed from the landmass didn't align perfectly with that defined in the geomorphology layer.
  • +
  • Fixed an issue in the CV model where the intensity of local wave exposure was very low, and yielded zero local wave power for the majority of coastal segments.
  • +
  • Fixed an issue where the CV model crashes if a coastal segment is at the edge of the shore exposure raster.
  • +
  • Fixed the exposure of segments surrounded by land that appeared as exposed when their depth was zero.
  • +
  • Fixed an issue in the CV model where the natural habitat values less than 5 were one unit too low, leading to negative habitat values in some cases.
  • +
  • Fixed an exponent issue in the CV model where the coastal vulnerability index was raised to a power that was too high.
  • +
  • Fixed a bug in the Scenic Quality model that prevented it from starting, as well as a number of other issues.
  • +
  • Updated the pollination model to conform with the latest InVEST geoprocessing standards, resulting in an approximately 33% speedup.
  • +
  • Improved the UI's ability to remember the last folder visited, and to have all file and folder selection dialogs have access to this information.
  • +
  • Fixed an issue in Marine Water Quality where the UV points were supposed to be optional, but instead raised an exception when not passed in.
  • +
+
+
+

3.0.0 (2014-03-23)

+

The 3.0.0 release of InVEST represents a shift away from the ArcGIS to the InVEST standalone computational platform. The only exception to this shift is the marine coastal protection tier 1 model which is still supported in an ArcGIS toolbox and has no InVEST 3.0 standalone at the moment. Specific changes are detailed below

+
    +
  • A standalone version of the aesthetic quality model has been developed and packaged along with this release. The standalone outperforms the ArcGIS equivalent and includes a valuation component. See the user's guide for details.
  • +
  • The core water routing algorithms for the sediment and nutrient models have been overhauled. The routing algorithms now correctly adjust flow in plateau regions, address a bug that would sometimes not route large sections of a DEM, and has been optimized for both run time and memory performance. In most cases the core d-infinity flow accumulation algorithm out performs TauDEM. We have also packaged a simple interface to these algorithms in a standalone tool called RouteDEM; the functions can also be referenced from the scripting API in the invest_natcap.routing package.
  • +
  • The sediment and nutrient models are now at a production level release. We no longer support the ArcGIS equivalent of these models.
  • +
  • The sediment model has had its outputs simplified with major changes including the removal of the 'pixel mean' outputs, a direct output of the pixel level export and retention maps, and a single output shapefile whose attribute table contains aggregations of sediment output values. Additionally all inputs to the sediment biophysical table including p, c, and retention coefficients are now expressed as a proportion between 0 and 1; the ArcGIS model had previously required those inputs were integer values between 0 and 1000. See the "Interpreting Results" section of sediment model for full details on the outputs.
  • +
  • The nutrient model has had a similar overhaul to the sediment model including a simplified output structure with many key outputs contained in the attribute table of the shapefile. Retention coefficients are also expressed in proportions between 0 and 1. See the "Interpreting Results" section of nutrient model for full details on the outputs.
  • +
  • Fixed a bug in Habitat Risk Assessment where the HRA module would incorrectly error if a criteria with a 0 score (meant to be removed from the assessment) had a 0 data quality or weight.
  • +
  • Fixed a bug in Habitat Risk Assessment where the average E/C/Risk values across the given subregion were evaluating to negative numbers.
  • +
  • Fixed a bug in Overlap Analysis where Human Use Hubs would error if run without inter-activity weighting, and Intra-Activity weighting would error if run without Human Use Hubs.
  • +
  • The runtime performance of the hydropower water yield model has been improved.
  • +
  • Released InVEST's implementation of the D-infinity flow algorithm in a tool called RouteDEM available from the start menu.
  • +
  • Unstable version of blue carbon available.
  • +
  • Unstable version of scenario generator available.
  • +
  • Numerous other minor bug fixes and performance enhacnements.
  • +
+
+
+

2.6.0 (2013-12-16)

+

The 2.6.0 release of InVEST removes most of the old InVEST models from the Arc toolbox in favor of the new InVEST standalone models. While we have been developing standalone equivalents for the InVEST Arc models since version 2.3.0, this is the first release in which we removed support for the deprecated ArcGIS versions after an internal review of correctness, performance, and stability on the standalones. Additionally, this is one of the last milestones before the InVEST 3.0.0 release later next year which will transition InVEST models away from strict ArcGIS dependence to a standalone form.

+

Specifically, support for the following models have been moved from the ArcGIS toolbox to their Windows based standalones: (1) hydropower/water yield, (2) finfish aquaculture, (3) coastal protection tier 0/coastal vulnerability, (4) wave energy, (5) carbon, (6) habitat quality/biodiversity, (7) pollination, (8) timber, and (9) overlap analysis. Additionally, documentation references to ArcGIS for those models have been replaced with instructions for launching standalone InVEST models from the Windows start menu.

+

This release also addresses minor bugs, documentation updates, performance tweaks, and new functionality to the toolset, including:

+
    +
  • A Google doc to provide guidance for scripting the InVEST standalone models: https://docs.google.com/document/d/158WKiSHQ3dBX9C3Kc99HUBic0nzZ3MqW3CmwQgvAqGo/edit?usp=sharing
  • +
  • Fixed a bug in the sample data that defined Kc as a number between 0 and 1000 instead of a number between 0 and 1.
  • +
  • Link to report an issue now takes user to the online forums rather than an email address.
  • +
  • Changed InVEST Sediment model standalone so that retention values are now between 0 and 1 instead of 0 and 100.
  • +
  • Fixed a bug in Biodiversity where if no suffix were entered output filenames would have a trailing underscore (_) behind them.
  • +
  • Added documentation to the water purification/nutrient retention model documentation about the standalone outputs since they differ from the ArcGIS version of the model.
  • +
  • Fixed an issue where the model would try to move the logfile to the workspace after the model run was complete and Windows would erroneously report that the move failed.
  • +
  • Removed the separation between marine and freshwater terrestrial models in the user's guide. Now just a list of models.
  • +
  • Changed the name of InVEST "Biodiversity" model to "Habitat Quality" in the module names, start menu, user's guide, and sample data folders.
  • +
  • Minor bug fixes, performance enhancements, and better error reporting in the internal infrastructure.
  • +
  • HRA risk in the unstable standalone is calculated differently from the last release. If there is no spatial overlap within a cell, there is automatically a risk of 0. This also applies to the E and C intermediate files for a given pairing. If there is no spatial overlap, E and C will be 0 where there is only habitat. However, we still create a recovery potential raster which has habitat- specific risk values, even without spatial overlap of a stressor. HRA shapefile outputs for high, medium, low risk areas are now calculated using a user-defined maximum number of overlapping stressors, rather than all potential stressors. In the HTML subregion averaged output, we now attribute what portion of risk to a habitat comes from each habitat-stressor pairing. Any pairings which don't overlap will have an automatic risk of 0.
  • +
  • Major changes to Water Yield : Reservoir Hydropower Production. Changes include an alternative equation for calculating Actual Evapotranspiration (AET) for non-vegetated land cover types including wetlands. This allows for a more accurate representation of processes on land covers such as urban, water, wetlands, where root depth values aren't applicable. To differentiate between the two equations a column 'LULC_veg' has been added to the Biophysical table in Hydropower/input/biophysical_table.csv. In this column a 1 indicates vegetated and 0 indicates non-vegetated.
  • +
  • The output structure and outputs have also change in Water Yield : Reservoir Hydropower Production. There is now a folder 'output' that contains all output files including a sub directory 'per_pixel' which has three pixel raster outputs. The subwatershed results are only calculated for the water yield portion and those results can be found as a shapefile, 'subwatershed_results.shp', and CSV file, 'subwatershed_results.csv'. The watershed results can be found in similar files: watershed_results.shp and watershed_results.csv. These two files for the watershed outputs will aggregate the Scarcity and Valuation results as well.
  • +
  • The evapotranspiration coefficients for crops, Kc, has been changed to a decimal input value in the biophysical table. These values used to be multiplied by 1000 so that they were in integer format, that pre processing step is no longer necessary.
  • +
  • Changing support from richsharp@stanford.edu to the user support forums at http://ncp-yamato.stanford.edu/natcapforums.
  • +
+
+
+

2.5.6 (2013-09-06)

+

The 2.5.6 release of InVEST that addresses minor bugs, performance tweaks, and new functionality of the InVEST standalone models. Including:

+
    +
  • Change the changed the Carbon biophysical table to use code field name from LULC to lucode so it is consistent with the InVEST water yield biophysical table.
  • +
  • Added Monte Carlo uncertainty analysis and documentation to finfish aquaculture model.
  • +
  • Replaced sample data in overlap analysis that was causing the model to crash.
  • +
  • Updates to the overlap analysis user's guide.
  • +
  • Added preprocessing toolkit available under C:{InVEST install directory}utils
  • +
  • Biodiversity Model now exits gracefully if a threat raster is not found in the input folder.
  • +
  • Wind Energy now uses linear (bilinear because its over 2D space?) interpolation.
  • +
  • Wind Energy has been refactored to current API.
  • +
  • Potential Evapotranspiration input has been properly named to Reference Evapotranspiration.
  • +
  • PET_mn for Water Yield is now Ref Evapotranspiration times Kc (evapotranspiration coefficient).
  • +
  • The soil depth field has been renamed 'depth to root restricting layer' in both the hydropower and nutrient retention models.
  • +
  • ETK column in biophysical table for Water Yield is now Kc.
  • +
  • Added help text to Timber model.
  • +
  • Changed the behavior of nutrient retention to return nodata values when the mean runoff index is zero.
  • +
  • Fixed an issue where the hydropower model didn't use the suffix inputs.
  • +
  • Fixed a bug in Biodiversity that did not allow for numerals in the threat names and rasters.
  • +
  • Updated routing algorithm to use a modern algorithm for plateau direction resolution.
  • +
  • Fixed an issue in HRA where individual risk pixels weren't being calculated correctly.
  • +
  • HRA will now properly detect in the preprocessed CSVs when criteria or entire habitat-stressor pairs are not desired within an assessment.
  • +
  • Added an infrastructure feature so that temporary files are created in the user's workspace rather than at the system level folder. This lets users work in a secondary workspace on a USB attached hard drive and use the space of that drive, rather than the primary operating system drive.
  • +
+
+
+

2.5.5 (2013-08-06)

+

The 2.5.5 release of InVEST that addresses minor bugs, performance tweaks, and new functionality of the InVEST standalone models. Including:

+
+
    +
  • +
    +
    Production level release of the 3.0 Coastal Vulnerability model.
    +
    +
      +
    • This upgrades the InVEST 2.5.4 version of the beta standalone CV to a full release with full users guide. This version of the CV model should be used in all cases over its ArcGIS equivalent.
    • +
    +
    +
    +
  • +
  • +
    +
    Production level release of the Habitat Risk Assessment model.
    +
    +
      +
    • This release upgrades the InVEST 2.5.4 beta version of the standalone habitat risk assessment model. It should be used in all cases over its ArcGIS equivalent.
    • +
    +
    +
    +
  • +
  • +
    +
    Uncertainty analysis in Carbon model (beta)
    +
    +
      +
    • Added functionality to assess uncertainty in sequestration and emissions given known uncertainty in carbon pool stocks. Users can now specify standard deviations of carbon pools with normal distributions as well as desired uncertainty levels. New outputs include masks for regions which both sequester and emit carbon with a high probability of confidence. Please see the "Uncertainty Analysis" section of the carbon user's guide chapter for more information.
    • +
    +
    +
    +
  • +
  • +
    +
    REDD+ Scenario Analysis in Carbon model (beta)
    +
    +
      +
    • Additional functionality to assist users evaluating REDD and REDD+ scenarios in the carbon model. The uncertainty analysis functionality can also be used with these scenarios. Please see the "REDD Scenario Analysis" section of the carbon user's guide chapter for more information.
    • +
    +
    +
    +
  • +
  • +
    +
    Uncertainty analysis in Finfish Aquaculture model (beta)
    +
    +
      +
    • Additionally functionality to account for uncertainty in alpha and beta growth parameters as well as histogram plots showing the distribution of harvest weights and net present value. Uncertainty analysis is performed through Monte Carlo runs that normally sample the growth parameters.
    • +
    +
    +
    +
  • +
  • +
    +
    Streamlined Nutrient Retention model functionality
    +
    +
      +
    • The nutrient retention module no longer requires users to explicitly run the water yield model. The model now seamlessly runs water yield during execution.
    • +
    +
    +
    +
  • +
  • +
    +
    Beta release of the recreation model
    +
    +
      +
    • The recreation is available for beta use with limited documentation.
    • +
    +
    +
    +
  • +
  • +
    +
    Full release of the wind energy model
    +
    +
      +
    • Removing the 'beta' designation on the wind energy model.
    • +
    +
    +
    +
  • +
+
+

Known Issues:

+
+
    +
  • Flow routing in the standalone sediment and nutrient models has a bug that prevents routing in some (not all) landscapes. This bug is related to resolving d-infinity flow directions across flat areas. We are implementing the solution in Garbrecht and Martx (1997). In the meanwhile the sediment and nutrient models are still marked as beta until this issue is resolved.
  • +
+
+
+
+

2.5.4 (2013-06-07)

+

This is a minor release of InVEST that addresses numerous minor bugs and performance tweaks in the InVEST 3.0 models. Including:

+
+
    +
  • +
    +
    Refactor of Wave Energy Model:
    +
    +
      +
    • Combining the Biophysical and Valuation modules into one.
    • +
    • Adding new data for the North Sea and Australia
    • +
    • Fixed a bug where elevation values that were equal to or greater than zero were being used in calculations.
    • +
    • Fixed memory issues when dealing with large datasets.
    • +
    • Updated core functions to remove any use of depracated functions
    • +
    +
    +
    +
  • +
  • Performance updates to the carbon model.
  • +
  • +
    +
    Nodata masking fix for rarity raster in Biodiversity Model.
    +
    +
      +
    • When computing rarity from a base landuse raster and current or future landuse raster, the intersection of the two was not being properly taken.
    • +
    +
    +
    +
  • +
  • Fixes to the flow routing algorithms in the sediment and nutrient retention models in cases where stream layers were burned in by ArcGIS hydro tools. In those cases streams were at the same elevation and caused routing issues.
  • +
  • Fixed an issue that affected several InVEST models that occured when watershed polygons were too small to cover a pixel. Excessively small watersheds are now handled correctly
  • +
  • Arc model deprecation. We are deprecating the following ArcGIS versions of our InVEST models in the sense we recommend ALL users use the InVEST standalones over the ArcGIS versions, and the existing ArcGIS versions of these models will be removed entirely in the next release. +
      +
    • Timber
    • +
    • Carbon
    • +
    • Pollination
    • +
    • Biodiversity
    • +
    • Finfish Aquaculture
    • +
    +
  • +
+
+

Known Issues:

+
+
    +
  • Flow routing in the standalone sediment and nutrient models has a bug that prevents routing in several landscapes. We're not certain of the nature of the bug at the moment, but we will fix by the next release. Thus, sediment and nutrient models are marked as (beta) since in some cases the DEM routes correctly.
  • +
+
+
+
+

2.5.3 (2013-03-21)

+

This is a minor release of InVEST that fixes an issue with the HRA model that caused ArcGIS versions of the model to fail when calculating habitat maps for risk hotspots. This upgrade is strongly recommended for users of InVEST 2.5.1 or 2.5.2.

+
+
+

2.5.2 (2013-03-17)

+

This is a minor release of InVEST that fixes an issue with the HRA sample data that caused ArcGIS versions of the model to fail on the training data. There is no need to upgrade for most users unless you are doing InVEST training.

+
+
+

2.5.1 (2013-03-12)

+

This is a minor release of InVEST that does not add any new models, but does add additional functionality, stability, and increased performance to one of the InVEST 3.0 standalones:

+
+
    +
  • +
    +
    Pollination 3.0 Beta:
    +
    +
      +
    • Fixed a bug where Windows users of InVEST could run the model, but most raster outputs were filled with nodata values.
    • +
    +
    +
    +
  • +
+
+

Additionally, this minor release fixes a bug in the InVEST user interface where collapsible containers became entirely non-interactive.

+
+
+

2.5.0 (2013-03-08)

+

This a major release of InVEST that includes new standalone versions (ArcGIS is not required) our models as well as additional functionality, stability, and increased performance to many of the existing models. This release is timed to support our group's annual training event at Stanford University. We expect to release InVEST 2.5.1 a couple of weeks after to address any software issues that arise during the training. See the release notes below for details of the release, and please contact richsharp@stanford.edu for any issues relating to software:

+
+
    +
  • +
    +
    new Sediment 3.0 Beta:
    +
    +
      +
    • This is a standalone model that executes an order of magnitude faster than the original ArcGIS model, but may have memory issues with larger datasets. This fix is scheduled for the 2.5.1 release of InVEST.
    • +
    • Uses a d-infinity flow algorithm (ArcGIS version uses D8).
    • +
    • Includes a more accurate LS factor.
    • +
    • Outputs are now summarized by polygon rather than rasterized polygons. Users can view results directly as a table rather than sampling a GIS raster.
    • +
    +
    +
    +
  • +
  • +
    +
    new Nutrient 3.0 Beta:
    +
    +
      +
    • This is a standalone model that executes an order of magnitude faster than the original ArcGIS model, but may have memory issues with larger datasets. This fix is scheduled for the 2.5.1 release of InVEST.
    • +
    • Uses a d-infinity flow algorithm (ArcGIS version uses D8).
    • +
    • Includes a more accurate LS factor.
    • +
    • Outputs are now summarized by polygon rather than rasterized polygons. Users can view results directly as a table rather than sampling a GIS raster.
    • +
    +
    +
    +
  • +
  • +
    +
    new Wind Energy:
    +
    +
      +
    • A new offshore wind energy model. This is a standalone-only model available under the windows start menu.
    • +
    +
    +
    +
  • +
  • +
    +
    new Recreation Alpha:
    +
    +
      +
    • This is a working demo of our soon to be released future land and near shore recreation model. The model itself is incomplete and should only be used as a demo or by NatCap partners that know what they're doing.
    • +
    +
    +
    +
  • +
  • +
    +
    new Habitat Risk Assessment 3.0 Alpha:
    +
    +
      +
    • This is a working demo of our soon to be released 3.0 version of habitat risk assessment. The model itself is incomplete and should only be used as a demo or by NatCap partners that know what they're doing. Users that need to use the habitat risk assessment should use the ArcGIS version of this model.
    • +
    +
    +
    +
  • +
  • +
    +
    Improvements to the InVEST 2.x ArcGIS-based toolset:
    +
    +
      +
    • Bug fixes to the ArcGIS based Coastal Protection toolset.
    • +
    +
    +
    +
  • +
  • Removed support for the ArcGIS invest_VERSION.mxd map. We expect to transition the InVEST toolset exclusive standalone tools in a few months. In preparation of this we are starting to deprecate parts of our old ArcGIS toolset including this ArcMap document. The InVEST ArcToolbox is still available in C:InVEST_2_5_0invest_250.tbx.
  • +
  • Known issues: +
      +
    • The InVEST 3.0 standalones generate open source GeoTiffs as outputs rather than the proprietary ESRI Grid format. ArcGIS 9.3.1 occasionally displays these rasters incorrectly. We have found that these layers can be visualized in ArcGIS 9.3.1 by following convoluted steps: Right Click on the layer and select Properties; click on the Symbology tab; select Stretch, agree to calculate a histogram (this will create an .aux file that Arc can use for visualization), click "Ok", remove the raster from the layer list, then add it back. As an alternative, we suggest using an open source GIS Desktop Tool like Quantum GIS or ArcGIS version 10.0 or greater.
    • +
    +
  • +
+
+
    +
  • The InVEST 3.0 carbon model will generate inaccurate sequestration results if the extents of the current and future maps don't align. This will be fixed in InVEST 2.5.1; in the meanwhile a workaround is to clip both LULCs so they have identical overlaps.
  • +
  • A user reported an unstable run of InVEST 3.0 water yield. We are not certain what is causing the issue, but we do have a fix that will go out in InVEST 2.5.1.
  • +
  • At the moment the InVEST standalones do not run on Windows XP. This appears to be related to an incompatibility between Windows XP and GDAL, the an open source gis library we use to create and read GIS data. At the moment we are uncertain if we will be able to fix this bug in future releases, but will pass along more information in the future.
  • +
+
+
+
+
+

2.4.5 (2013-02-01)

+

This is a minor release of InVEST that does not add any new models, but does add additional functionality, stability, and increased performance to many of the InVEST 3.0 standalones:

+
+
    +
  • +
    +
    Pollination 3.0 Beta:
    +
    +
      +
    • Greatly improved memory efficiency over previous versions of this model.
    • +
    • 3.0 Beta Pollination Biophysical and Valuation have been merged into a single tool, run through a unified user interface.
    • +
    • Slightly improved runtime through the use of newer core InVEST GIS libraries.
    • +
    • Optional ability to weight different species individually. This feature adds a column to the Guilds table that allows the user to specify a relative weight for each species, which will be used before combining all species supply rasters.
    • +
    • Optional ability to aggregate pollinator abundances at specific points provided by an optional points shapefile input.
    • +
    • Bugfix: non-agricultural pixels are set to a value of 0.0 to indicate no value on the farm value output raster.
    • +
    • Bugfix: sup_val_<beename>_<scenario>.tif rasters are now saved to the intermediate folder inside the user's workspace instead of the output folder.
    • +
    +
    +
    +
  • +
  • +
    +
    Carbon Biophysical 3.0 Beta:
    +
    +
      +
    • Tweaked the user interface to require the user to provide a future LULC raster when the 'Calculate Sequestration' checkbox is checked.
    • +
    • Fixed a bug that restricted naming of harvest layers. Harvest layers are now selected simply by taking the first available layer.
    • +
    +
    +
    +
  • +
  • Better memory efficiency in hydropower model.
  • +
  • Better support for unicode filepaths in all 3.0 Beta user interfaces.
  • +
  • Improved state saving and retrieval when loading up previous-run parameters in all 3.0 Beta user interfaces.
  • +
  • All 3.0 Beta tools now report elapsed time on completion of a model.
  • +
  • All 3.0 Beta tools now provide disk space usage reports on completion of a model.
  • +
  • All 3.0 Beta tools now report arguments at the top of each logfile.
  • +
  • Biodiversity 3.0 Beta: The half-saturation constant is now allowed to be a positive floating-point number.
  • +
  • Timber 3.0 Beta: Validation has been added to the user interface for this tool for all tabular and shapefile inputs.
  • +
  • Fixed some typos in Equation 1 in the Finfish Aquaculture user's guide.
  • +
  • Fixed a bug where start menu items were not getting deleted during an InVEST uninstall.
  • +
  • Added a feature so that if the user selects to download datasets but the datasets don't successfully download the installation alerts the user and continues normally.
  • +
  • Fixed a typo with tau in aquaculture guide, originally said 0.8, really 0.08.
  • +
  • +
    +
    Improvements to the InVEST 2.x ArcGIS-based toolset:
    +
    +
      +
    • Minor bugfix to Coastal Vulnerability, where an internal unit of measurements was off by a couple digits in the Fetch Calculator.
    • +
    • Minor fixes to various helper tools used in InVEST 2.x models.
    • +
    • Outputs for Hargreaves are now saved as geoTIFFs.
    • +
    • Thornwaite allows more flexible entering of hours of sunlight.
    • +
    +
    +
    +
  • +
+
+
+
+

2.4.4 (2012-10-24)

+
    +
  • Fixes memory errors experienced by some users in the Carbon Valuation 3.0 Beta model.
  • +
  • Minor improvements to logging in the InVEST User Interface
  • +
  • Fixes an issue importing packages for some officially-unreleased InVEST models.
  • +
+
+
+

2.4.3 (2012-10-19)

+
    +
  • Fixed a minor issue with hydropower output vaulation rasters whose statistics were not pre-calculated. This would cause the range in ArcGIS to show ther rasters at -3e38 to 3e38.
  • +
  • The InVEST installer now saves a log of the installation process to InVEST_<version>install_log.txt
  • +
  • Fixed an issue with Carbon 3.0 where carbon output values were incorrectly calculated.
  • +
  • Added a feature to Carbon 3.0 were total carbon stored and sequestered is output as part of the running log.
  • +
  • Fixed an issue in Carbon 3.0 that would occur when users had text representations of floating point numbers in the carbon pool dbf input file.
  • +
  • Added a feature to all InVEST 3.0 models to list disk usage before and after each run and in most cases report a low free space error if relevant.
  • +
+
+
+

2.4.2 (2012-10-15)

+
    +
  • Fixed an issue with the ArcMap document where the paths to default data were not saved as relative paths. This caused the default data in the document to not be found by ArcGIS.
  • +
  • Introduced some more memory-efficient processing for Biodiversity 3.0 Beta. This fixes an out-of-memory issue encountered by some users when using very large raster datasets as inputs.
  • +
+
+
+

2.4.1 (2012-10-08)

+
    +
  • Fixed a compatibility issue with ArcGIS 9.3 where the ArcMap and ArcToolbox were unable to be opened by Arc 9.3.
  • +
+
+
+

2.4.0 (2012-10-05)

+

Changes in InVEST 2.4.0

+

General:

+

This is a major release which releases two additional beta versions of the InVEST models in the InVEST 3.0 framework. Additionally, this release introduces start menu shortcuts for all available InVEST 3.0 beta models. Existing InVEST 2.x models can still be found in the included Arc toolbox.

+

Existing InVEST models migrated to the 3.0 framework in this release include:

+
    +
  • +
    +
    Biodiversity 3.0 Beta
    +
    +
      +
    • Minor bug fixes and usability enhancements
    • +
    • Runtime decreased by a factor of 210
    • +
    +
    +
    +
  • +
  • +
    +
    Overlap Analysis 3.0 Beta
    +
    +
      +
    • In most cases runtime decreased by at least a factor of 15
    • +
    • Minor bug fixes and usability enhancements
    • +
    • +
      +
      Split into two separate tools:
      +
      +
        +
      • Overlap Analysis outputs rasters with individually-weighted pixels
      • +
      • Overlap Analysis: Management Zones produces a shapefile output.
      • +
      +
      +
      +
    • +
    • Updated table format for input activity CSVs
    • +
    • Removed the "grid the seascape" step
    • +
    +
    +
    +
  • +
+

Updates to ArcGIS models:

+
    +
  • +
    +
    Coastal vulnerability
    +
    +
      +
    • Removed the "structures" option
    • +
    • Minor bug fixes and usability enhancements
    • +
    +
    +
    +
  • +
  • +
    +
    Coastal protection (erosion protection)
    +
    +
      +
    • Incorporated economic valuation option
    • +
    • Minor bug fixes and usability enhancements
    • +
    +
    +
    +
  • +
+

Additionally there are a handful of minor fixes and feature enhancements:

+
    +
  • InVEST 3.0 Beta standalones (identified by a new InVEST icon) may be run from the Start Menu (on windows navigate to Start Menu -> All Programs -> InVEST 2.4.0
  • +
  • Bug fixes for the calculation of raster statistics.
  • +
  • InVEST 3.0 wave energy no longer requires an AOI for global runs, but encounters memory issues on machines with less than 4GB of RAM. This is a known issue that will be fixed in a minor release.
  • +
  • Minor fixes to several chapters in the user's guide.
  • +
  • Minor bug fix to the 3.0 Carbon model: harvest maps are no longer required inputs.
  • +
  • Other minor bug fixes and runtime performance tweaks in the 3.0 framework.
  • +
  • Improved installer allows users to remove InVEST from the Windows Add/Remove programs menu.
  • +
  • Fixed a visualization bug with wave energy where output rasters did not have the min/max/stdev calculations on them. This made the default visualization in arc be a gray blob.
  • +
+
+
+

2.3.0 (2012-08-02)

+

Changes in InVEST 2.3.0

+

General:

+

This is a major release which releases several beta versions of the InVEST models in the InVEST 3.0 framework. These models run as standalones, but a GIS platform is needed to edit and view the data inputs and outputs. Until InVEST 3.0 is released the original ArcGIS based versions of these tools will remain the release.

+

Existing InVEST models migrated to the 3.0 framework in this release include:

+
    +
  • +
    +
    Reservoir Hydropower Production 3.0 beta
    +
    +
      +
    • Minor bug fixes.
    • +
    +
    +
    +
  • +
  • +
    +
    Finfish Aquaculture
    +
    +
      +
    • Minor bug fixes and usability enhancements.
    • +
    +
    +
    +
  • +
  • +
    +
    Wave Energy 3.0 beta
    +
    +
      +
    • Runtimes for non-global runs decreased by a factor of 7
    • +
    • Minor bugs in interpolation that exist in the 2.x model is fixed in 3.0 beta.
    • +
    +
    +
    +
  • +
  • +
    +
    Crop Pollination 3.0 beta
    +
    +
      +
    • Runtimes decreased by a factor of over 10,000
    • +
    +
    +
    +
  • +
+

This release also includes the new models which only exist in the 3.0 framework:

+
    +
  • Marine Water Quality 3.0 alpha with a preliminary user's guide.
  • +
+

InVEST models in the 3.0 framework from previous releases that now have a standalone executable include:

+
    +
  • Managed Timber Production Model
  • +
  • Carbon Storage and Sequestration
  • +
+

Additionally there are a handful of other minor fixes and feature enhancements since the previous release:

+
    +
  • Minor bug fix to 2.x sedimentation model that now correctly calculates slope exponentials.
  • +
  • Minor fixes to several chapters in the user's guide.
  • +
  • The 3.0 version of the Carbon model now can value the price of carbon in metric tons of C or CO2.
  • +
  • Other minor bug fixes and runtime performance tweaks in the 3.0 framework.
  • +
+
+
+

2.2.2 (2012-03-03)

+

Changes in InVEST 2.2.2

+

General:

+

This is a minor release which fixes the following defects:

+
+
-Fixed an issue with sediment retention model where large watersheds
+
allowed loading per cell was incorrectly rounded to integer values.
+
-Fixed bug where changing the threshold didn't affect the retention output
+
because function was incorrectly rounded to integer values.
+
+

-Added total water yield in meters cubed to to output table by watershed.

+
+
-Fixed bug where smaller than default (2000) resolutions threw an error about
+
not being able to find the field in "unitynew". With non-default resolution, "unitynew" was created without an attribute table, so one was created by force.
+
-Removed mention of beta state and ecoinformatics from header of software
+
license.
+
-Modified overlap analysis toolbox so it reports an error directly in the
+
toolbox if the workspace name is too long.
+
+
+
+

2.2.1 (2012-01-26)

+

Changes in InVEST 2.2.1

+

General:

+

This is a minor release which fixes the following defects:

+

-A variety of miscellaneous bugs were fixed that were causing crashes of the Coastal Protection model in Arc 9.3. -Fixed an issue in the Pollination model that was looking for an InVEST1005 directory. -The InVEST "models only" release had an entry for the InVEST 3.0 Beta tools, but was missing the underlying runtime. This has been added to the models only 2.2.1 release at the cost of a larger installer. -The default InVEST ArcMap document wouldn't open in ArcGIS 9.3. It can now be opened by Arc 9.3 and above. -Minor updates to the Coastal Protection user's guide.

+
+
+

2.2.0 (2011-12-22)

+

In this release we include updates to the habitat risk assessment model, updates to Coastal Vulnerability Tier 0 (previously named Coastal Protection), and a new tier 1 Coastal Vulnerability tool. Additionally, we are releasing a beta version of our 3.0 platform that includes the terrestrial timber and carbon models.

+

See the "Marine Models" and "InVEST 3.0 Beta" sections below for more details.

+

Marine Models

+
    +
  1. Marine Python Extension Check +

    This tool has been updated to include extension requirements for the new Coastal Protection T1 model. It also reflects changes to the Habitat Risk Assessment and Coastal Protection T0 models, as they no longer require the PythonWin extension.

    +
  2. +
  3. Habitat Risk Assessment (HRA) +

    This model has been updated and is now part of three-step toolset. The first step is a new Ratings Survey Tool which eliminates the need for Microsoft Excel when users are providing habitat-stressor ratings. This Survey Tool now allows users to up- and down-weight the importance of various criteria. For step 2, a copy of the Grid the Seascape tool has been placed in the HRA toolset. In the last step, users will run the HRA model which includes the following updates:

    +
      +
    • New habitat outputs classifying risk as low, medium, and high
    • +
    • Model run status updates (% complete) in the message window
    • +
    • Improved habitat risk plots embedded in the output HTML
    • +
    +
  4. +
  5. Coastal Protection +

    This module is now split into sub-models, each with two parts. The first sub-model is Coastal Vulnerability (Tier 0) and the new addition is Coastal Protection (Tier 1).

    +

    Coastal Vulnerability (T0) Step 1) Fetch Calculator - there are no updates to this tool. Step 2) Vulnerability Index

    +
      +
    • Wave Exposure: In this version of the model, we define wave exposure for sites facing the open ocean as the maximum of the weighted average of wave's power coming from the ocean or generated by local winds. We weight wave power coming from each of the 16 equiangular sector by the percent of time that waves occur in that sector, and based on whether or not fetch in that sector exceeds 20km. For sites that are sheltered, wave exposure is the average of wave power generated by the local storm winds weighted by the percent occurrence of those winds in each sector. This new method takes into account the seasonality of wind and wave patterns (storm waves generally come from a preferential direction), and helps identify regions that are not exposed to powerful waves although they are open to the ocean (e.g. the leeside of islands).
    • +
    • Natural Habitats: The ranking is now computed using the rank of all natural habitats present in front of a segment, and we weight the lowest ranking habitat 50% more than all other habitats. Also, rankings and protective distance information are to be provided by CSV file instead of Excel. With this new method, shoreline segments that have more habitats than others will have a lower risk of inundation and/or erosion during storms.
    • +
    • Structures: The model has been updated to now incorporate the presence of structures by decreasing the ranking of shoreline segments that adjoin structures.
    • +
    +

    Coastal Protection (T1) - This is a new model which plots the amount of sandy beach erosion or consolidated bed scour that backshore regions experience in the presence or absence of natural habitats. It is composed of two steps: a Profile Generator and Nearshore Waves and Erosion. It is recommended to run the Profile Generator before the Nearshore Waves and Erosion model.

    +

    Step 1) Profile Generator: This tool helps the user generate a 1-dimensional bathymetric and topographic profile perpendicular to the shoreline at the user-defined location. This model provides plenty of guidance for building backshore profiles for beaches, marshes and mangroves. It will help users modify bathymetry profiles that they already have, or can generate profiles for sandy beaches if the user has not bathymetric data. Also, the model estimates and maps the location of natural habitats present in front of the region of interest. Finally, it provides sample wave and wind data that can be later used in the Nearshore Waves and Erosion model, based on computed fetch values and default Wave Watch III data.

    +

    Step 2) Nearshore Waves and Erosion: This model estimates profiles of beach erosion or values of rates of consolidated bed scour at a site as a function of the type of habitats present in the area of interest. The model takes into account the protective effects of vegetation, coral and oyster reefs, and sand dunes. It also shows the difference of protection provided when those habitats are present, degraded, or gone.

    +
  6. +
  7. Aesthetic Quality +

    This model no longer requires users to provide a projection for Overlap Analysis. Instead, it uses the projection from the user-specified Area of Interest (AOI) polygon. Additionally, the population estimates for this model have been fixed.

    +
  8. +
+

InVEST 3.0 Beta

+

The 2.2.0 release includes a preliminary version of our InVEST 3.0 beta platform. It is included as a toolset named "InVEST 3.0 Beta" in the InVEST220.tbx. It is currently only supported with ArcGIS 10. To launch an InVEST 3.0 beta tool, double click on the desired tool in the InVEST 3.0 toolset then click "Ok" on the Arc toolbox screen that opens. The InVEST 3.0 tool panel has inputs very similar to the InVEST 2.2.0 versions of the tools with the following modifications:

+
+
InVEST 3.0 Carbon:
+
+
    +
  • Fixes a minor bug in the 2.2 version that ignored floating point values in carbon pool inputs.
  • +
  • Separation of carbon model into a biophysical and valuation model.
  • +
  • Calculates carbon storage and sequestration at the minimum resolution of the input maps.
  • +
  • Runtime efficiency improved by an order of magnitude.
  • +
  • User interface streamlined including dynamic activation of inputs based on user preference, direct link to documentation, and recall of inputs based on user's previous run.
  • +
+
+
InVEST 3.0 Timber:
+
+
    +
  • User interface streamlined including dynamic activation of inputs based on user preference, direct link to documentation, and recall of inputs based on user's previous run.
  • +
+
+
+
+
+

2.1.1 (2011-10-17)

+

Changes in InVEST 2.1.1

+

General:

+

This is a minor release which fixes the following defects:

+

-A truncation error was fixed on nutrient retention and sedimentation model that involved division by the number of cells in a watershed. Now correctly calculates floating point division. -Minor typos were fixed across the user's guide.

+
+
+

2.1 Beta (2011-05-11)

+

Updates to InVEST Beta

+

InVEST 2.1 . Beta

+

Changes in InVEST 2.1

+

General:

+

1. InVEST versioning We have altered our versioning scheme. Integer changes will reflect major changes (e.g. the addition of marine models warranted moving from 1.x to 2.0). An increment in the digit after the primary decimal indicates major new features (e.g the addition of a new model) or major revisions. For example, this release is numbered InVEST 2.1 because two new models are included). We will add another decimal to reflect minor feature revisions or bug fixes. For example, InVEST 2.1.1 will likely be out soon as we are continually working to improve our tool. 2. HTML guide With this release, we have migrated the entire InVEST users. guide to an HTML format. The HTML version will output a pdf version for use off-line, printing, etc.

+

MARINE MODELS

+

1.Marine Python Extension Check

+

-This tool has been updated to allow users to select the marine models they intend to run. Based on this selection, it will provide a summary of which Python and ArcGIS extensions are necessary and if the Python extensions have been successfully installed on the user.s machine.

+

2.Grid the Seascape (GS)

+

-This tool has been created to allow marine model users to generate an seascape analysis grid within a specified area of interest (AOI).

+

-It only requires an AOI and cell size (in meters) as inputs, and produces a polygon grid which can be used as inputs for the Habitat Risk Assessment and Overlap Analysis models.

+
    +
  1. Coastal Protection
  2. +
+
    +
  • This is now a two-part model for assessing Coastal Vulnerability. The first part is a tool for calculating fetch and the second maps the value of a Vulnerability Index, which differentiates areas with relatively high or low exposure to erosion and inundation during storms.
  • +
  • The model has been updated to now incorporate coastal relief and the protective influence of up to eight natural habitat input layers.
  • +
  • A global Wave Watch 3 dataset is also provided to allow users to quickly generate rankings for wind and wave exposure worldwide.
  • +
+
    +
  1. Habitat Risk Assessment (HRA)
  2. +
+

This new model allows users to assess the risk posed to coastal and marine habitats by human activities and the potential consequences of exposure for the delivery of ecosystem services and biodiversity. The HRA model is suited to screening the risk of current and future human activities in order to prioritize management strategies that best mitigate risk.

+
    +
  1. Overlap Analysis
  2. +
+

This new model maps current human uses in and around the seascape and summarizes the relative importance of various regions for particular activities. The model was designed to produce maps that can be used to identify marine and coastal areas that are most important for human use, in particular recreation and fisheries, but also other activities.

+

FRESHWATER MODELS

+

All Freshwater models now support ArcMap 10.

+

Sample data:

+
    +
  1. Bug fix for error in Water_Tables.mdb Biophysical table where many field values were shifted over one column relative to the correct field name.
  2. +
  3. Bug fix for incorrect units in erosivity layer.
  4. +
+

Hydropower:

+

1.In Water Yield, new output tables have been added containing mean biophysical outputs (precipitation, actual and potential evapotranspiration, water yield) for each watershed and sub-watershed.

+

Water Purification:

+
    +
  1. The Water Purification Threshold table now allows users to specify separate thresholds for nitrogen and phosphorus. Field names thresh_n and thresh_p replace the old ann_load.
  2. +
  3. The Nutrient Retention output tables nutrient_watershed.dbf and nutrient_subwatershed.dbf now include a column for nutrient retention per watershed/sub-watershed.
  4. +
  5. In Nutrient Retention, some output file names have changed.
  6. +
  7. The user's guide has been updated to explain more accurately the inclusion of thresholds in the biophysical service estimates.
  8. +
+

Sedimentation:

+
    +
  1. The Soil Loss output tables sediment_watershed.dbf and sediment_subwatershed.dbf now include a column for sediment retention per watershed/sub-watershed.
  2. +
  3. In Soil Loss, some output file names have changed.
  4. +
  5. The default input value for Slope Threshold is now 75.
  6. +
  7. The user's guide has been updated to explain more accurately the inclusion of thresholds in the biophysical service estimates.
  8. +
  9. Valuation: Bug fix where the present value was not being applied correctly.
  10. +
+
+
+

2.0 Beta (2011-02-14)

+

Changes in InVEST 2.0

+

InVEST 1.005 is a minor release with the following modification:

+
    +
  1. Aesthetic Quality +

    This new model allows users to determine the locations from which new nearshore or offshore features can be seen. It generates viewshed maps that can be used to identify the visual footprint of new offshore development.

    +
  2. +
  3. Coastal Vulnerability +

    This new model produces maps of coastal human populations and a coastal exposure to erosion and inundation index map. These outputs can be used to understand the relative contributions of different variables to coastal exposure and to highlight the protective services offered by natural habitats.

    +
  4. +
  5. Aquaculture +

    This new model is used to evaluate how human activities (e.g., addition or removal of farms, changes in harvest management practices) and climate change (e.g., change in sea surface temperature) may affect the production and economic value of aquacultured Atlantic salmon.

    +
  6. +
  7. Wave Energy +

    This new model provides spatially explicit information, showing potential areas for siting Wave Energy conversion (WEC) facilities with the greatest energy production and value. This site- and device-specific information for the WEC facilities can then be used to identify and quantify potential trade-offs that may arise when siting WEC facilities.

    +
  8. +
  9. Avoided Reservoir Sedimentation +
      +
    • The name of this model has been changed to the Sediment Retention model.
    • +
    • We have added a water quality valuation model for sediment retention. The user now has the option to select avoided dredge cost analysis, avoided water treatment cost analysis or both. The water quality valuation approach is the same as that used in the Water Purification: Nutrient Retention model.
    • +
    • The threshold information for allowed sediment loads (TMDL, dead volume, etc.) are now input in a stand alone table instead of being included in the valuation table. This adjusts the biophysical service output for any social allowance of pollution. Previously, the adjustment was only done in the valuation model.
    • +
    • The watersheds and sub-watershed layers are now input as shapefiles instead of rasters.
    • +
    • Final outputs are now aggregated to the sub-basin scale. The user must input a sub-basin shapefile. We provide the Hydro 1K dataset as a starting option. See users guide for changes to many file output names.
    • +
    • Users are strongly advised not to interpret pixel-scale outputs for hydrological understanding or decision-making of any kind. Pixel outputs should only be used for calibration/validation or model checking.
    • +
    +
  10. +
  11. Hydropower Production +
      +
    • The watersheds and sub-watershed layers are now input as shapefiles instead of rasters.
    • +
    • Final outputs are now aggregated to the sub-basin scale. The user must input a sub-basin shapefile. We provide the Hydro 1K dataset as a starting option. See users guide for changes to many file output names.
    • +
    • Users are strongly advised not to interpret pixel-scale outputs for hydrological understanding or decision-making of any kind. Pixel outputs should only be used for calibration/validation or model checking.
    • +
    • The calibration constant for each watershed is now input in a stand-alone table instead of being included in the valuation table. This makes running the water scarcity model simpler.
    • +
    +
  12. +
  13. Water Purification: Nutrient Retention +
      +
    • The threshold information for allowed pollutant levels (TMDL, etc.) are now input in a stand alone table instead of being included in the valuation table. This adjusts the biophysical service output for any social allowance of pollution. Previously, the adjustment was only done in the valuation model.
    • +
    • The watersheds and sub-watershed layers are now input as shapefiles instead of rasters.
    • +
    • Final outputs are now aggregated to the sub-basin scale. The user must input a sub-basin shapefile. We provide the Hydro 1K dataset as a starting option. See users guide for changes to many file output names.
    • +
    • Users are strongly advised not to interpret pixel-scale outputs for hydrological understanding or decision-making of any kind. Pixel outputs should only be used for calibration/validation or model checking.
    • +
    +
  14. +
  15. Carbon Storage and Sequestration +

    The model now outputs an aggregate sum of the carbon storage.

    +
  16. +
  17. Habitat Quality and Rarity +

    This model had an error while running ReclassByACII if the land cover codes were not sorted alphabetically. This has now been corrected and it sorts the reclass file before running the reclassification

    +

    The model now outputs an aggregate sum of the habitat quality.

    +
  18. +
  19. Pollination +

    In this version, the pollination model accepts an additional parameter which indicated the proportion of a crops yield that is attributed to wild pollinators.

    +
  20. +
+
+ + \ No newline at end of file From c6ba8bbc776b64db2266285b789f52fa494e0089 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Thu, 7 Nov 2024 16:25:22 -0700 Subject: [PATCH 45/90] Add changelog modal tests --- workbench/src/renderer/components/Changelog/index.jsx | 5 ++++- .../src/renderer/components/DataDownloadModal/index.jsx | 5 ++++- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/workbench/src/renderer/components/Changelog/index.jsx b/workbench/src/renderer/components/Changelog/index.jsx index d49bdf688c..3885e641a2 100644 --- a/workbench/src/renderer/components/Changelog/index.jsx +++ b/workbench/src/renderer/components/Changelog/index.jsx @@ -50,9 +50,12 @@ export default function Changelog(props) { show={props.show && htmlContent !== ''} onHide={props.close} size="lg" + aria-labelledby="changelog-modal-title" > - {t('New in this version')} + + {t('New in this version')} + - - {/* Setting inner HTML in this way is OK because - the HTML content is controlled by our build process - and not, for example, sourced from user input. */} - - - - ); + + + + {/* Setting inner HTML in this way is OK because + the HTML content is controlled by our build process + and not, for example, sourced from user input. */} + + + + ); } Changelog.propTypes = { - show: PropTypes.bool.isRequired, - close: PropTypes.func.isRequired, + show: PropTypes.bool.isRequired, + close: PropTypes.func.isRequired, }; diff --git a/workbench/tests/renderer/changelog.test.js b/workbench/tests/renderer/changelog.test.js index 96286860f8..330a53126d 100644 --- a/workbench/tests/renderer/changelog.test.js +++ b/workbench/tests/renderer/changelog.test.js @@ -7,75 +7,70 @@ import App from '../../src/renderer/app'; import pkg from '../../package.json'; describe('Changelog', () => { - const currentVersion = pkg.version; - const nonexistentVersion = 'nonexistent-version'; - beforeEach(() => { - jest.spyOn(window, 'fetch') - .mockResolvedValue({ - text: () => ` - - - -
-

${currentVersion}

-
-
-

${nonexistentVersion}

-
- - - ` - }); - }); + const currentVersion = pkg.version; + const nonexistentVersion = 'nonexistent-version'; + beforeEach(() => { + jest.spyOn(window, 'fetch') + .mockResolvedValue({ + text: () => ` + + + +
+

${currentVersion}

+
+
+

${nonexistentVersion}

+
+ + + ` + }); + }); - test('Changelog modal opens immediately on launch of a new version', async () => { - const { findByRole } = render(); - const changelogModal = await findByRole('dialog', { name: 'New in this version' }); - expect(changelogModal).toBeInTheDocument(); - }); + test('Changelog modal opens immediately on launch of a new version', async () => { + const { findByRole } = render(); + const changelogModal = await findByRole('dialog', { name: 'New in this version' }); + expect(changelogModal).toBeInTheDocument(); + }); - test('On first run (of any version), Changelog modal opens after Download modal is closed', async () => { - const { findByRole, getByText } = render(); + test('On first run (of any version), Changelog modal opens after Download modal is closed', async () => { + const { findByRole, getByText } = render(); - let changelogModalFound = true; - try { - await findByRole('dialog', { name: 'New in this version' }); - } catch { - changelogModalFound = false; - } - expect(changelogModalFound).toBe(false); + let changelogModalFound = true; + try { + await findByRole('dialog', { name: 'New in this version' }); + } catch { + changelogModalFound = false; + } + expect(changelogModalFound).toBe(false); - const downloadModal = await findByRole('dialog', { name: 'Download InVEST sample data' }); - expect(downloadModal).toBeInTheDocument(); + const downloadModal = await findByRole('dialog', { name: 'Download InVEST sample data' }); + expect(downloadModal).toBeInTheDocument(); - await userEvent.click(getByText('Cancel')); - expect(downloadModal).not.toBeInTheDocument(); - const changelogModal = await findByRole('dialog', { name: 'New in this version' }); - expect(changelogModal).toBeInTheDocument(); - }); + await userEvent.click(getByText('Cancel')); + expect(downloadModal).not.toBeInTheDocument(); + const changelogModal = await findByRole('dialog', { name: 'New in this version' }); + expect(changelogModal).toBeInTheDocument(); + }); - test('Changelog modal does not open when current version has been run before', async () => { - const { findByRole } = render(); - let changelogModalFound = true; - try { - await findByRole('dialog', { name: 'New in this version' }); - } catch { - changelogModalFound = false; - } - expect(changelogModalFound).toBe(false); - }); + test('Changelog modal does not open when current version has been run before', async () => { + const { findByRole } = render(); + let changelogModalFound = true; + try { + await findByRole('dialog', { name: 'New in this version' }); + } catch { + changelogModalFound = false; + } + expect(changelogModalFound).toBe(false); + }); - test('Changelog modal contains only content relevant to the current version', async () => { - const { findByRole } = render(); - const currentVersionSectionHeading = await findByRole('heading', { name: currentVersion }); - expect(currentVersionSectionHeading).toBeInTheDocument(); + test('Changelog modal contains only content relevant to the current version', async () => { + const { findByRole, queryByRole } = render(); + const currentVersionSectionHeading = await findByRole('heading', { name: currentVersion }); + expect(currentVersionSectionHeading).toBeInTheDocument(); - let nonexistentVersionSectionFound = true; - try { - await findByRole('heading', { name: nonexistentVersion }); - } catch { - nonexistentVersionSectionFound = false; - } - expect(nonexistentVersionSectionFound).toBe(false); - }); + const nonexistentVersionSectionHeading = queryByRole('heading', { name: nonexistentVersion }); + expect(nonexistentVersionSectionHeading).not.toBeInTheDocument(); + }); }); From 0dbcb0ecfc9b14c0bc9276d5ef5e079114c33928 Mon Sep 17 00:00:00 2001 From: Emily Davis Date: Mon, 11 Nov 2024 15:45:32 -0700 Subject: [PATCH 53/90] Open changelog links in browser instead of in an Electron window --- .../src/renderer/components/Changelog/index.jsx | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/workbench/src/renderer/components/Changelog/index.jsx b/workbench/src/renderer/components/Changelog/index.jsx index e840e75e4d..3ae2114dec 100644 --- a/workbench/src/renderer/components/Changelog/index.jsx +++ b/workbench/src/renderer/components/Changelog/index.jsx @@ -45,6 +45,20 @@ export default function Changelog(props) { loadHtml(); }, []); + // Once HTML content has loaded, set up links to open in browser + // (instead of in an Electron window). + useEffect(() => { + const openLinkInBrowser = (event) => { + event.preventDefault(); + ipcRenderer.send( + ipcMainChannels.OPEN_EXTERNAL_URL, event.currentTarget.href + ); + }; + document.querySelectorAll('.link-external').forEach(link => { + link.addEventListener('click', openLinkInBrowser); + }); + }, [htmlContent]); + return ( Date: Mon, 11 Nov 2024 16:53:21 -0700 Subject: [PATCH 54/90] Add error handling --- .../renderer/components/Changelog/index.jsx | 53 +++++++++++-------- 1 file changed, 30 insertions(+), 23 deletions(-) diff --git a/workbench/src/renderer/components/Changelog/index.jsx b/workbench/src/renderer/components/Changelog/index.jsx index 3ae2114dec..933db6675b 100644 --- a/workbench/src/renderer/components/Changelog/index.jsx +++ b/workbench/src/renderer/components/Changelog/index.jsx @@ -9,6 +9,7 @@ import pkg from '../../../../package.json'; import { ipcMainChannels } from '../../../main/ipcMainChannels'; const { ipcRenderer } = window.Workbench.electron; +const { logger } = window.Workbench; export default function Changelog(props) { const { t } = useTranslation(); @@ -17,30 +18,36 @@ export default function Changelog(props) { // Load HTML from external file (which is generated by Python build process). useEffect(() => { async function loadHtml() { - const baseUrl = await ipcRenderer.invoke(ipcMainChannels.BASE_URL) - fetch(`${baseUrl}/changelog.html`) - .then(response => response.text()) - .then(htmlString => { - // Find the section whose heading explicitly matches the current version. - const versionStr = pkg.version; - const escapedVersionStr = versionStr.split('.').join('\\.'); - const sectionRegex = new RegExp( - `[\\s]*?

${escapedVersionStr}\\b[\\s\\S]*?

[\\s\\S]*?` + const baseUrl = await ipcRenderer.invoke(ipcMainChannels.BASE_URL); + const response = await fetch(`${baseUrl}/changelog.html`); + if (!response.ok) { + logger.debug(`Error fetching changelog HTML: ${response.status} ${response.statusText}`); + return; + } + try { + const htmlString = await response.text(); + // Find the section whose heading explicitly matches the current version. + const versionStr = pkg.version; + const escapedVersionStr = versionStr.split('.').join('\\.'); + const sectionRegex = new RegExp( + `[\\s]*?

${escapedVersionStr}\\b[\\s\\S]*?

[\\s\\S]*?` + ); + const sectionMatches = htmlString.match(sectionRegex); + if (sectionMatches && sectionMatches.length) { + let latestVersionSection = sectionMatches[0]; + const linkRegex = / Date: Mon, 11 Nov 2024 17:04:39 -0700 Subject: [PATCH 55/90] Update tests --- workbench/tests/renderer/changelog.test.js | 1 + 1 file changed, 1 insertion(+) diff --git a/workbench/tests/renderer/changelog.test.js b/workbench/tests/renderer/changelog.test.js index 330a53126d..8b1bcd3eba 100644 --- a/workbench/tests/renderer/changelog.test.js +++ b/workbench/tests/renderer/changelog.test.js @@ -12,6 +12,7 @@ describe('Changelog', () => { beforeEach(() => { jest.spyOn(window, 'fetch') .mockResolvedValue({ + ok: true, text: () => ` From dca481173f71d58a32931d77807298dab1c2349f Mon Sep 17 00:00:00 2001 From: Dave Fisher Date: Wed, 13 Nov 2024 11:00:17 -0500 Subject: [PATCH 56/90] updates related to python environments and package installation --- README.rst | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) diff --git a/README.rst b/README.rst index 7505f6736b..7c2f54260d 100644 --- a/README.rst +++ b/README.rst @@ -35,7 +35,6 @@ General Information Dependencies ------------ -Run ``make check`` to test if all required dependencies are installed on your system. OS-specific installation instructions are found either online at http://invest.readthedocs.io/en/latest/installing.html or locally at ``doc/api-docs/installing.rst``. @@ -57,10 +56,7 @@ Or on Windows, use the following instead from a CMD prompt:: > make env > .\env\bin\activate -This makefile target is included for convenience ... you may of course choose to -manage your own virtual environment. ``requirements.txt``, -``requirements-dev.txt`` and ``requirements-docs.txt`` list the python -dependencies needed. +This makefile target is included for convenience. It uses ``conda`` and installs packages from ``conda-forge``. Using a different environment name """""""""""""""""""""""""""""""""" @@ -74,13 +70,25 @@ You could then activate the environment created at ``myEnv``. Using a different environment management tool """"""""""""""""""""""""""""""""""""""""""""" -The InVEST Makefile uses ``virtualenv`` to set up an environment, but this is -not the only `environment management tool out there -`_. -You may elect to manage your virtual environment a different way, independent -of ``make env``. The only requirement for the build process is that the required -tools are available on your PATH and the required python packages can be imported. +You may of course choose to manage your own virtual environment without using the Makefile. + +We suggest using ``conda`` or ``mamba`` and ``conda-forge``. + +``requirements.txt``, ``requirements-dev.txt`` and ``requirements-docs.txt`` list the python +dependencies needed. + +Installing ``natcap.invest`` from local source code +""""""""""""""""""""""""""""""""""""""""""""""""""" +From an activated virtual environment:: + + $ make install + +In practice, it can be convenient to use an "editable install" instead to avoid needing +to re-install after making changes to source code:: + + $ pip install -e . +But note that any changes to non-Python files will still require compilation. Building InVEST Distributions ----------------------------- From c257f38c69f8057f1227e91474e63cc75eaffb06 Mon Sep 17 00:00:00 2001 From: Dave Fisher Date: Wed, 13 Nov 2024 11:13:57 -0500 Subject: [PATCH 57/90] added readme notes on external repositories --- README.rst | 37 ++++++++++++++++++++++--------------- 1 file changed, 22 insertions(+), 15 deletions(-) diff --git a/README.rst b/README.rst index 7c2f54260d..41dc47dd27 100644 --- a/README.rst +++ b/README.rst @@ -153,6 +153,13 @@ To build the user's guide:: This will build HTML and PDF documentation, writing them to ``dist/userguide`` and ``dist/InVEST_*_Documentation.pdf``, respectively. +The User's Guide is maintained in a separate git reporsitory. InVEST will build +the User's Guide with the commit defined in the ``Makefile``:: + + GIT_UG_REPO := https://github.com/natcap/invest.users-guide + GIT_UG_REPO_PATH := doc/users-guide + GIT_UG_REPO_REV := f203ec069f9f03560c9a85b268e67ebb6b994953 + API Documentation +++++++++++++++++ @@ -176,22 +183,12 @@ build zip archives of the sample data:: This will write the data zipfiles to ``dist/data``. ``git`` command is needed. -Single archive of sample data -+++++++++++++++++++++++++++++ - -For trainings, it is especially convenient to distribute all sample data as a -single zip archive. As an added bonus, this single zip archive can be provided -to the InVEST installer for Windows as either the 'Advanced' input on the front -page of the installer, or by a CLI flag, thus preventing the installer from -downloading datasets from the internet. See -``installer/windows/invest_installer.nsi`` for more details. To build a single -archive of all InVEST sample data:: - - $ make sampledata_single - -This will write the single sampledata archive to -``dist/InVEST_*_sample_data.zip``. +Sample data is tracked in a ``git-lfs`` repo and will be packaged based on the commit +defined in the ``Makefile``:: + GIT_SAMPLE_DATA_REPO := https://bitbucket.org/natcap/invest-sample-data.git + GIT_SAMPLE_DATA_REPO_PATH := $(DATA_DIR)/invest-sample-data + GIT_SAMPLE_DATA_REPO_REV := 0f8b41557753dad3670ba8220f41650b51435a93 Tests ----- @@ -205,6 +202,16 @@ To run tests on the suite of Ecosystem Service models in InVEST:: $ make test +Tests depend on test data that is tracked in a ``git-lfs`` repo defined in the ``Makefile``:: + + GIT_TEST_DATA_REPO := https://bitbucket.org/natcap/invest-test-data.git + GIT_TEST_DATA_REPO_PATH := $(DATA_DIR)/invest-test-data + GIT_TEST_DATA_REPO_REV := 324abde73e1d770ad75921466ecafd1ec6297752 + +Test data (and Sample Data) can be retrieved using:: + + $ make fetch + Changing how GNU make runs tests ++++++++++++++++++++++++++++++++ From 23a91a823063ed7b73f3de0bba97a08144aacd96 Mon Sep 17 00:00:00 2001 From: Dave Fisher Date: Thu, 14 Nov 2024 09:18:06 -0500 Subject: [PATCH 58/90] a few more details on installing invest --- README.rst | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/README.rst b/README.rst index 41dc47dd27..5df4bc8e02 100644 --- a/README.rst +++ b/README.rst @@ -79,16 +79,26 @@ dependencies needed. Installing ``natcap.invest`` from local source code """"""""""""""""""""""""""""""""""""""""""""""""""" -From an activated virtual environment:: +From an activated virtual environment, it's safest to uninstall any existing installation +and then install `natcap.invest`:: + $ pip uninstall natcap.invest $ make install In practice, it can be convenient to use an "editable install" instead to avoid needing -to re-install after making changes to source code:: +to uninstall & re-install after making changes to source code:: $ pip install -e . -But note that any changes to non-Python files will still require compilation. +Note that with an editable install any changes to non-Python (Cython, C++) files will +require compilation using one of the above installation methods. + +*The Workbench is not part of the* ``natcap.invest`` *Python package. See* +``workbench/readme.md`` *for developer details.* + +A successful ``natcap.invest`` installation will include the InVEST CLI:: + + $ invest list Building InVEST Distributions ----------------------------- @@ -153,7 +163,7 @@ To build the user's guide:: This will build HTML and PDF documentation, writing them to ``dist/userguide`` and ``dist/InVEST_*_Documentation.pdf``, respectively. -The User's Guide is maintained in a separate git reporsitory. InVEST will build +The User's Guide is maintained in a separate git repository. InVEST will build the User's Guide with the commit defined in the ``Makefile``:: GIT_UG_REPO := https://github.com/natcap/invest.users-guide From 27bc49977d3c3dc4f9b633de781b78b7dbfe6d10 Mon Sep 17 00:00:00 2001 From: Dave Fisher Date: Fri, 15 Nov 2024 09:29:07 -0500 Subject: [PATCH 59/90] noting that `make env` creates the env in the cwd --- README.rst | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/README.rst b/README.rst index 5df4bc8e02..0e98605a3d 100644 --- a/README.rst +++ b/README.rst @@ -57,15 +57,16 @@ Or on Windows, use the following instead from a CMD prompt:: > .\env\bin\activate This makefile target is included for convenience. It uses ``conda`` and installs packages from ``conda-forge``. +It also uses the `-p` flag with `conda create`, creating a `./env` folder containing the environment. -Using a different environment name -"""""""""""""""""""""""""""""""""" -If you prefer a different name for your environment, you may pass the environment name as +Using a different environment folder name +""""""""""""""""""""""""""""""""""""""""" +If you prefer a different path for your environment, you may pass the environment path as a parameter to make:: $ make ENV=myEnv env -You could then activate the environment created at ``myEnv``. +You could then activate the environment created at ``./myEnv``. Using a different environment management tool From d28d0682a97cb3dc7b9bd366f5b34e1a64296a72 Mon Sep 17 00:00:00 2001 From: davemfish Date: Fri, 15 Nov 2024 13:15:12 -0500 Subject: [PATCH 60/90] use VectorTranslate instead of CopyDataSource for convenience and reliability. #1686 --- tests/test_coastal_vulnerability.py | 19 +++---------------- 1 file changed, 3 insertions(+), 16 deletions(-) diff --git a/tests/test_coastal_vulnerability.py b/tests/test_coastal_vulnerability.py index a6e6f60887..ae96cf6793 100644 --- a/tests/test_coastal_vulnerability.py +++ b/tests/test_coastal_vulnerability.py @@ -931,14 +931,8 @@ def test_final_risk_calc(self): REGRESSION_DATA, 'coastal_exposure.gpkg') # This input gets modified in place, so first copy to working dir - # I'm using GPKG driver to copy because that driver may have problems - # updating a file created by a different GPKG driver version, and the - # version used is dependent on GDAL version. - # https://gdal.org/drivers/vector/gpkg.html - base_shore_point_vector = ogr.Open(base_vector_path) - gpkg_driver = ogr.GetDriverByName('GPKG') - gpkg_driver.CopyDataSource( - base_shore_point_vector, target_point_vector_path) + base_shore_point_vector = gdal.OpenEx(base_vector_path, gdal.OF_VECTOR) + gdal.VectorTranslate(target_point_vector_path, base_shore_point_vector) coastal_vulnerability.calculate_final_risk( target_point_vector_path, target_point_csv_path) @@ -968,17 +962,10 @@ def test_final_risk_calc_with_missing_data(self): # This gpkg has a feature with an empty field value for 'R_slr' # The function modifies the file in place, so copy to test workspace # first. - - # I'm using GPKG driver to copy because that driver may have problems - # updating a file created by a different GPKG driver version, and the - # version used is dependent on GDAL version. - # https://gdal.org/drivers/vector/gpkg.html base_vector_path = os.path.join( REGRESSION_DATA, 'test_missing_values.gpkg') base_shore_point_vector = ogr.Open(base_vector_path) - gpkg_driver = ogr.GetDriverByName('GPKG') - gpkg_driver.CopyDataSource( - base_shore_point_vector, target_vector_path) + gdal.VectorTranslate(target_vector_path, base_shore_point_vector) coastal_vulnerability.calculate_final_risk( target_vector_path, target_csv_path) From dd5e5696697e6828f012611dbfba2505eb061d2d Mon Sep 17 00:00:00 2001 From: davemfish Date: Fri, 15 Nov 2024 15:38:45 -0500 Subject: [PATCH 61/90] use VectorTranslate instead of CopyDataSource for convenience and reliability; nature access. #1686 --- src/natcap/invest/urban_nature_access.py | 9 ++++----- tests/test_urban_nature_access.py | 14 ++++++++++---- 2 files changed, 14 insertions(+), 9 deletions(-) diff --git a/src/natcap/invest/urban_nature_access.py b/src/natcap/invest/urban_nature_access.py index 136575a956..56c12ebae5 100644 --- a/src/natcap/invest/urban_nature_access.py +++ b/src/natcap/invest/urban_nature_access.py @@ -2093,11 +2093,10 @@ def _write_supply_demand_vector(source_aoi_vector_path, feature_attrs, Returns: ``None`` """ - source_vector = ogr.Open(source_aoi_vector_path) - driver = ogr.GetDriverByName('GPKG') - driver.CopyDataSource(source_vector, target_aoi_vector_path) - source_vector = None - driver = None + gdal.VectorTranslate( + target_aoi_vector_path, source_aoi_vector_path, + format='GPKG', + preserveFID=True) target_vector = gdal.OpenEx(target_aoi_vector_path, gdal.GA_Update) target_layer = target_vector.GetLayer() diff --git a/tests/test_urban_nature_access.py b/tests/test_urban_nature_access.py index a3d3d7b43c..881e354c91 100644 --- a/tests/test_urban_nature_access.py +++ b/tests/test_urban_nature_access.py @@ -904,8 +904,14 @@ def test_write_vector(self): from natcap.invest import urban_nature_access args = _build_model_args(self.workspace_dir) + admin_vector = gdal.OpenEx(args['admin_boundaries_vector_path']) + admin_layer = admin_vector.GetLayer() + fid = admin_layer.GetNextFeature().GetFID() + admin_layer = None + admin_vector = None + feature_attrs = { - 0: { + fid: { 'my-field-1': float(1.2345), 'my-field-2': numpy.float32(2.34567), 'my-field-3': numpy.float64(3.45678), @@ -924,10 +930,10 @@ def test_write_vector(self): vector = gdal.OpenEx(target_vector_path) self.assertEqual(vector.GetLayerCount(), 1) layer = vector.GetLayer() - self.assertEqual(len(layer.schema), len(feature_attrs[0])) + self.assertEqual(len(layer.schema), len(feature_attrs[fid])) self.assertEqual(layer.GetFeatureCount(), 1) - feature = layer.GetFeature(0) - for field_name, expected_field_value in feature_attrs[0].items(): + feature = layer.GetFeature(fid) + for field_name, expected_field_value in feature_attrs[fid].items(): self.assertEqual( feature.GetField(field_name), expected_field_value) finally: From 00c9243ad9e64636e9ba786b9bb1ebf9ceaf54b2 Mon Sep 17 00:00:00 2001 From: davemfish Date: Fri, 15 Nov 2024 15:47:12 -0500 Subject: [PATCH 62/90] use VectorTranslate instead of CopyDataSource for convenience and reliability; wind energy. #1686 --- src/natcap/invest/wind_energy.py | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/natcap/invest/wind_energy.py b/src/natcap/invest/wind_energy.py index 252e4811db..d9e4651578 100644 --- a/src/natcap/invest/wind_energy.py +++ b/src/natcap/invest/wind_energy.py @@ -1758,10 +1758,9 @@ def _calculate_land_to_grid_distance( # Copy the point vector _, driver_name = _get_file_ext_and_driver_name( target_land_vector_path) - base_land_vector = ogr.Open(base_land_vector_path, gdal.OF_VECTOR) - driver = ogr.GetDriverByName(driver_name) - driver.CopyDataSource(base_land_vector, target_land_vector_path) - base_land_vector = None + gdal.VectorTranslate( + target_land_vector_path, base_land_vector_path, + format=driver_name) target_land_vector = gdal.OpenEx( target_land_vector_path, gdal.OF_VECTOR | gdal.GA_Update) From b623e28e02da3951058e00987e16e4d3c9e41dc7 Mon Sep 17 00:00:00 2001 From: davemfish Date: Fri, 15 Nov 2024 16:05:01 -0500 Subject: [PATCH 63/90] no need to open the dataset before translating it. #1686 --- tests/test_coastal_vulnerability.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/tests/test_coastal_vulnerability.py b/tests/test_coastal_vulnerability.py index ae96cf6793..3ca634c757 100644 --- a/tests/test_coastal_vulnerability.py +++ b/tests/test_coastal_vulnerability.py @@ -964,8 +964,7 @@ def test_final_risk_calc_with_missing_data(self): # first. base_vector_path = os.path.join( REGRESSION_DATA, 'test_missing_values.gpkg') - base_shore_point_vector = ogr.Open(base_vector_path) - gdal.VectorTranslate(target_vector_path, base_shore_point_vector) + gdal.VectorTranslate(target_vector_path, base_vector_path) coastal_vulnerability.calculate_final_risk( target_vector_path, target_csv_path) From ad59b739d2ccc87cff5ddae1cfaa9171564bcc5a Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 19 Nov 2024 13:32:18 -0800 Subject: [PATCH 64/90] enable gdal.UseExceptions in entrypoints and tests Enable gdal exceptions in the CLI and server. Update all models to expect and handle gdal exceptions where they are now raised. --- src/natcap/invest/cli.py | 504 +++++++++--------- src/natcap/invest/coastal_vulnerability.py | 52 +- .../invest/forest_carbon_edge_effect.py | 19 +- .../invest/recreation/recmodel_client.py | 18 +- src/natcap/invest/utils.py | 4 +- src/natcap/invest/validation.py | 23 +- src/natcap/invest/wave_energy.py | 21 +- src/natcap/invest/wind_energy.py | 70 +-- tests/test_annual_water_yield.py | 3 +- tests/test_carbon.py | 1 + tests/test_cli.py | 3 +- tests/test_coastal_blue_carbon.py | 1 + tests/test_coastal_vulnerability.py | 75 +-- tests/test_crop_production.py | 1 + tests/test_datastack.py | 1 + tests/test_delineateit.py | 1 + tests/test_forest_carbon_edge.py | 2 +- tests/test_habitat_quality.py | 1 + tests/test_hra.py | 1 + tests/test_invest.py | 2 + tests/test_model_specs.py | 2 + tests/test_ndr.py | 1 + tests/test_pollination.py | 2 + tests/test_recreation.py | 1 + tests/test_routedem.py | 1 + tests/test_scenario_proximity.py | 2 + tests/test_scenic_quality.py | 1 + tests/test_sdr.py | 1 + tests/test_seasonal_water_yield_regression.py | 1 + tests/test_spec_utils.py | 2 + tests/test_stormwater.py | 2 +- tests/test_translation.py | 2 + tests/test_ucm.py | 1 + tests/test_ufrm.py | 1 + tests/test_ui_server.py | 2 + tests/test_urban_nature_access.py | 1 + tests/test_usage_logging.py | 1 + tests/test_utils.py | 30 +- tests/test_validation.py | 1 + tests/test_wave_energy.py | 1 + tests/test_wind_energy.py | 1 + 41 files changed, 430 insertions(+), 430 deletions(-) diff --git a/src/natcap/invest/cli.py b/src/natcap/invest/cli.py index c4ff04829a..27c8ae8f60 100644 --- a/src/natcap/invest/cli.py +++ b/src/natcap/invest/cli.py @@ -19,6 +19,7 @@ from natcap.invest import spec_utils from natcap.invest import ui_server from natcap.invest import utils +from pygeoprocessing.geoprocessing_core import GDALUseExceptions DEFAULT_EXIT_CODE = 1 @@ -218,267 +219,268 @@ def main(user_args=None): so models may be run in this way without having GUI packages installed. """ - parser = argparse.ArgumentParser( - description=( - 'Integrated Valuation of Ecosystem Services and Tradeoffs. ' - 'InVEST (Integrated Valuation of Ecosystem Services and ' - 'Tradeoffs) is a family of tools for quantifying the values of ' - 'natural capital in clear, credible, and practical ways. In ' - 'promising a return (of societal benefits) on investments in ' - 'nature, the scientific community needs to deliver knowledge and ' - 'tools to quantify and forecast this return. InVEST enables ' - 'decision-makers to quantify the importance of natural capital, ' - 'to assess the tradeoffs associated with alternative choices, ' - 'and to integrate conservation and human development. \n\n' - 'Older versions of InVEST ran as script tools in the ArcGIS ' - 'ArcToolBox environment, but have almost all been ported over to ' - 'a purely open-source python environment.'), - prog='invest' - ) - parser.add_argument('--version', action='version', - version=natcap.invest.__version__) - verbosity_group = parser.add_mutually_exclusive_group() - verbosity_group.add_argument( - '-v', '--verbose', dest='verbosity', default=0, action='count', - help=('Increase verbosity. Affects how much logging is printed to ' - 'the console and (if running in headless mode) how much is ' - 'written to the logfile.')) - verbosity_group.add_argument( - '--debug', dest='log_level', default=logging.ERROR, - action='store_const', const=logging.DEBUG, - help='Enable debug logging. Alias for -vvv') - - parser.add_argument( - '--taskgraph-log-level', dest='taskgraph_log_level', default='ERROR', - type=str, choices=['DEBUG', 'INFO', 'WARNING', 'ERROR'], - help=('Set the logging level for Taskgraph. Affects how much logging ' - 'Taskgraph prints to the console and (if running in headless ' - 'mode) how much is written to the logfile.')) - - # list the language code and corresponding language name (in that language) - supported_languages_string = ', '.join([ - f'{locale} ({display_name})' - for locale, display_name in natcap.invest.LOCALE_NAME_MAP.items()]) - parser.add_argument( - '-L', '--language', default='en', - choices=natcap.invest.LOCALES, - help=('Choose a language. Model specs, names, and validation messages ' - 'will be translated. Log messages are not translated. Value ' - 'should be an ISO 639-1 language code. Supported options are: ' - f'{supported_languages_string}.')) - - subparsers = parser.add_subparsers(dest='subcommand') - - listmodels_subparser = subparsers.add_parser( - 'list', help='List the available InVEST models') - listmodels_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - - run_subparser = subparsers.add_parser( - 'run', help='Run an InVEST model') - # Recognize '--headless' for backwards compatibility. - # This arg is otherwise unused. - run_subparser.add_argument( - '-l', '--headless', action='store_true', - help=argparse.SUPPRESS) - run_subparser.add_argument( - '-d', '--datastack', default=None, nargs='?', - help=('Run the specified model with this JSON datastack. ' - 'Required if using --headless')) - run_subparser.add_argument( - '-w', '--workspace', default=None, nargs='?', - help=('The workspace in which outputs will be saved. ' - 'Required if using --headless')) - run_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model to run. Use "invest list" to list the available ' - 'models.')) - - validate_subparser = subparsers.add_parser( - 'validate', help=( - 'Validate the parameters of a datastack')) - validate_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - validate_subparser.add_argument( - 'datastack', help=('Path to a JSON datastack.')) - - getspec_subparser = subparsers.add_parser( - 'getspec', help=('Get the specification of a model.')) - getspec_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - getspec_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model for which the spec should be fetched. Use "invest ' - 'list" to list the available models.')) - - serve_subparser = subparsers.add_parser( - 'serve', help=('Start the flask app on the localhost.')) - serve_subparser.add_argument( - '--port', type=int, default=56789, - help='Port number for the Flask server') - - export_py_subparser = subparsers.add_parser( - 'export-py', help=('Save a python script that executes a model.')) - export_py_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model that the python script will execute. Use "invest ' - 'list" to list the available models.')) - export_py_subparser.add_argument( - '-f', '--filepath', default=None, - help='Define a location for the saved .py file') - - args = parser.parse_args(user_args) - natcap.invest.set_locale(args.language) - - root_logger = logging.getLogger() - handler = logging.StreamHandler(sys.stdout) - formatter = logging.Formatter( - fmt='%(asctime)s %(name)-18s %(levelname)-8s %(message)s', - datefmt='%m/%d/%Y %H:%M:%S ') - handler.setFormatter(formatter) - - # Set the log level based on what the user provides in the available - # arguments. Verbosity: the more v's the lower the logging threshold. - # If --debug is used, the logging threshold is 10. - # If the user goes lower than logging.DEBUG, default to logging.DEBUG. - log_level = min(args.log_level, logging.ERROR - (args.verbosity*10)) - handler.setLevel(max(log_level, logging.DEBUG)) # don't go below DEBUG - root_logger.addHandler(handler) - LOGGER.info('Setting handler log level to %s', log_level) - - # Set the log level for taskgraph. - taskgraph_log_level = logging.getLevelName(args.taskgraph_log_level.upper()) - logging.getLogger('taskgraph').setLevel(taskgraph_log_level) - LOGGER.debug('Setting taskgraph log level to %s', taskgraph_log_level) - - # FYI: Root logger by default has a level of logging.WARNING. - # To capture ALL logging produced in this system at runtime, use this: - # logging.getLogger().setLevel(logging.DEBUG) - # Also FYI: using logging.DEBUG means that the logger will defer to - # the setting of the parent logger. - logging.getLogger('natcap').setLevel(logging.DEBUG) - - if args.subcommand == 'list': - # reevaluate the model names in the new language - importlib.reload(model_metadata) - if args.json: - message = build_model_list_json() - else: - message = build_model_list_table() - - sys.stdout.write(message) - parser.exit() - - if args.subcommand == 'validate': - try: - parsed_datastack = datastack.extract_parameter_set(args.datastack) - except Exception as error: - parser.exit( - 1, "Error when parsing JSON datastack:\n " + str(error)) - - # reload validation module first so it's also in the correct language - importlib.reload(importlib.import_module('natcap.invest.validation')) - model_module = importlib.reload(importlib.import_module( - name=parsed_datastack.model_name)) - - try: - validation_result = model_module.validate(parsed_datastack.args) - except KeyError as missing_keys_error: + with GDALUseExceptions(): + parser = argparse.ArgumentParser( + description=( + 'Integrated Valuation of Ecosystem Services and Tradeoffs. ' + 'InVEST (Integrated Valuation of Ecosystem Services and ' + 'Tradeoffs) is a family of tools for quantifying the values of ' + 'natural capital in clear, credible, and practical ways. In ' + 'promising a return (of societal benefits) on investments in ' + 'nature, the scientific community needs to deliver knowledge and ' + 'tools to quantify and forecast this return. InVEST enables ' + 'decision-makers to quantify the importance of natural capital, ' + 'to assess the tradeoffs associated with alternative choices, ' + 'and to integrate conservation and human development. \n\n' + 'Older versions of InVEST ran as script tools in the ArcGIS ' + 'ArcToolBox environment, but have almost all been ported over to ' + 'a purely open-source python environment.'), + prog='invest' + ) + parser.add_argument('--version', action='version', + version=natcap.invest.__version__) + verbosity_group = parser.add_mutually_exclusive_group() + verbosity_group.add_argument( + '-v', '--verbose', dest='verbosity', default=0, action='count', + help=('Increase verbosity. Affects how much logging is printed to ' + 'the console and (if running in headless mode) how much is ' + 'written to the logfile.')) + verbosity_group.add_argument( + '--debug', dest='log_level', default=logging.ERROR, + action='store_const', const=logging.DEBUG, + help='Enable debug logging. Alias for -vvv') + + parser.add_argument( + '--taskgraph-log-level', dest='taskgraph_log_level', default='ERROR', + type=str, choices=['DEBUG', 'INFO', 'WARNING', 'ERROR'], + help=('Set the logging level for Taskgraph. Affects how much logging ' + 'Taskgraph prints to the console and (if running in headless ' + 'mode) how much is written to the logfile.')) + + # list the language code and corresponding language name (in that language) + supported_languages_string = ', '.join([ + f'{locale} ({display_name})' + for locale, display_name in natcap.invest.LOCALE_NAME_MAP.items()]) + parser.add_argument( + '-L', '--language', default='en', + choices=natcap.invest.LOCALES, + help=('Choose a language. Model specs, names, and validation messages ' + 'will be translated. Log messages are not translated. Value ' + 'should be an ISO 639-1 language code. Supported options are: ' + f'{supported_languages_string}.')) + + subparsers = parser.add_subparsers(dest='subcommand') + + listmodels_subparser = subparsers.add_parser( + 'list', help='List the available InVEST models') + listmodels_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + + run_subparser = subparsers.add_parser( + 'run', help='Run an InVEST model') + # Recognize '--headless' for backwards compatibility. + # This arg is otherwise unused. + run_subparser.add_argument( + '-l', '--headless', action='store_true', + help=argparse.SUPPRESS) + run_subparser.add_argument( + '-d', '--datastack', default=None, nargs='?', + help=('Run the specified model with this JSON datastack. ' + 'Required if using --headless')) + run_subparser.add_argument( + '-w', '--workspace', default=None, nargs='?', + help=('The workspace in which outputs will be saved. ' + 'Required if using --headless')) + run_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model to run. Use "invest list" to list the available ' + 'models.')) + + validate_subparser = subparsers.add_parser( + 'validate', help=( + 'Validate the parameters of a datastack')) + validate_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + validate_subparser.add_argument( + 'datastack', help=('Path to a JSON datastack.')) + + getspec_subparser = subparsers.add_parser( + 'getspec', help=('Get the specification of a model.')) + getspec_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + getspec_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model for which the spec should be fetched. Use "invest ' + 'list" to list the available models.')) + + serve_subparser = subparsers.add_parser( + 'serve', help=('Start the flask app on the localhost.')) + serve_subparser.add_argument( + '--port', type=int, default=56789, + help='Port number for the Flask server') + + export_py_subparser = subparsers.add_parser( + 'export-py', help=('Save a python script that executes a model.')) + export_py_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model that the python script will execute. Use "invest ' + 'list" to list the available models.')) + export_py_subparser.add_argument( + '-f', '--filepath', default=None, + help='Define a location for the saved .py file') + + args = parser.parse_args(user_args) + natcap.invest.set_locale(args.language) + + root_logger = logging.getLogger() + handler = logging.StreamHandler(sys.stdout) + formatter = logging.Formatter( + fmt='%(asctime)s %(name)-18s %(levelname)-8s %(message)s', + datefmt='%m/%d/%Y %H:%M:%S ') + handler.setFormatter(formatter) + + # Set the log level based on what the user provides in the available + # arguments. Verbosity: the more v's the lower the logging threshold. + # If --debug is used, the logging threshold is 10. + # If the user goes lower than logging.DEBUG, default to logging.DEBUG. + log_level = min(args.log_level, logging.ERROR - (args.verbosity*10)) + handler.setLevel(max(log_level, logging.DEBUG)) # don't go below DEBUG + root_logger.addHandler(handler) + LOGGER.info('Setting handler log level to %s', log_level) + + # Set the log level for taskgraph. + taskgraph_log_level = logging.getLevelName(args.taskgraph_log_level.upper()) + logging.getLogger('taskgraph').setLevel(taskgraph_log_level) + LOGGER.debug('Setting taskgraph log level to %s', taskgraph_log_level) + + # FYI: Root logger by default has a level of logging.WARNING. + # To capture ALL logging produced in this system at runtime, use this: + # logging.getLogger().setLevel(logging.DEBUG) + # Also FYI: using logging.DEBUG means that the logger will defer to + # the setting of the parent logger. + logging.getLogger('natcap').setLevel(logging.DEBUG) + + if args.subcommand == 'list': + # reevaluate the model names in the new language + importlib.reload(model_metadata) if args.json: - message = json.dumps( - {'validation_results': { - str(list(missing_keys_error.args)): 'Key is missing'}}) + message = build_model_list_json() else: - message = ('Datastack is missing keys:\n ' + - str(missing_keys_error.args)) + message = build_model_list_table() - # Missing keys have an exit code of 1 because that would indicate - # probably programmer error. sys.stdout.write(message) - parser.exit(1) - except Exception as error: - parser.exit( - 1, ('Datastack could not be validated:\n ' + - str(error))) + parser.exit() - # Even validation errors will have an exit code of 0 - if args.json: - message = json.dumps({ - 'validation_results': validation_result}) - else: - message = pprint.pformat(validation_result) + if args.subcommand == 'validate': + try: + parsed_datastack = datastack.extract_parameter_set(args.datastack) + except Exception as error: + parser.exit( + 1, "Error when parsing JSON datastack:\n " + str(error)) + + # reload validation module first so it's also in the correct language + importlib.reload(importlib.import_module('natcap.invest.validation')) + model_module = importlib.reload(importlib.import_module( + name=parsed_datastack.model_name)) + + try: + validation_result = model_module.validate(parsed_datastack.args) + except KeyError as missing_keys_error: + if args.json: + message = json.dumps( + {'validation_results': { + str(list(missing_keys_error.args)): 'Key is missing'}}) + else: + message = ('Datastack is missing keys:\n ' + + str(missing_keys_error.args)) + + # Missing keys have an exit code of 1 because that would indicate + # probably programmer error. + sys.stdout.write(message) + parser.exit(1) + except Exception as error: + parser.exit( + 1, ('Datastack could not be validated:\n ' + + str(error))) - sys.stdout.write(message) - parser.exit(0) + # Even validation errors will have an exit code of 0 + if args.json: + message = json.dumps({ + 'validation_results': validation_result}) + else: + message = pprint.pformat(validation_result) - if args.subcommand == 'getspec': - target_model = model_metadata.MODEL_METADATA[args.model].pyname - model_module = importlib.reload( - importlib.import_module(name=target_model)) - spec = model_module.MODEL_SPEC + sys.stdout.write(message) + parser.exit(0) - if args.json: - message = spec_utils.serialize_args_spec(spec) - else: - message = pprint.pformat(spec) - sys.stdout.write(message) - parser.exit(0) - - if args.subcommand == 'run': - if args.headless: - warnings.warn( - '--headless (-l) is now the default (and only) behavior ' - 'for `invest run`. This flag will not be recognized ' - 'in the future.', FutureWarning, stacklevel=2) # 2 for brevity - if not args.datastack: - parser.exit(1, 'Datastack required for execution.') - - try: - parsed_datastack = datastack.extract_parameter_set(args.datastack) - except Exception as error: - parser.exit( - 1, "Error when parsing JSON datastack:\n " + str(error)) + if args.subcommand == 'getspec': + target_model = model_metadata.MODEL_METADATA[args.model].pyname + model_module = importlib.reload( + importlib.import_module(name=target_model)) + spec = model_module.MODEL_SPEC - if not args.workspace: - if ('workspace_dir' not in parsed_datastack.args or - parsed_datastack.args['workspace_dir'] in ['', None]): + if args.json: + message = spec_utils.serialize_args_spec(spec) + else: + message = pprint.pformat(spec) + sys.stdout.write(message) + parser.exit(0) + + if args.subcommand == 'run': + if args.headless: + warnings.warn( + '--headless (-l) is now the default (and only) behavior ' + 'for `invest run`. This flag will not be recognized ' + 'in the future.', FutureWarning, stacklevel=2) # 2 for brevity + if not args.datastack: + parser.exit(1, 'Datastack required for execution.') + + try: + parsed_datastack = datastack.extract_parameter_set(args.datastack) + except Exception as error: parser.exit( - 1, ('Workspace must be defined at the command line ' - 'or in the datastack file')) - else: - parsed_datastack.args['workspace_dir'] = args.workspace - - target_model = model_metadata.MODEL_METADATA[args.model].pyname - model_module = importlib.import_module(name=target_model) - LOGGER.info('Imported target %s from %s', - model_module.__name__, model_module) - - with utils.prepare_workspace(parsed_datastack.args['workspace_dir'], - name=parsed_datastack.model_name, - logging_level=log_level): - LOGGER.log(datastack.ARGS_LOG_LEVEL, - 'Starting model with parameters: \n%s', - datastack.format_args_dict(parsed_datastack.args, - parsed_datastack.model_name)) - - # We're deliberately not validating here because the user - # can just call ``invest validate `` to validate. - # - # Exceptions will already be logged to the logfile but will ALSO be - # written to stdout if this exception is uncaught. This is by - # design. - model_module.execute(parsed_datastack.args) - - if args.subcommand == 'serve': - ui_server.app.run(port=args.port) - parser.exit(0) - - if args.subcommand == 'export-py': - target_filepath = args.filepath - if not args.filepath: - target_filepath = f'{args.model}_execute.py' - export_to_python(target_filepath, args.model) - parser.exit() + 1, "Error when parsing JSON datastack:\n " + str(error)) + + if not args.workspace: + if ('workspace_dir' not in parsed_datastack.args or + parsed_datastack.args['workspace_dir'] in ['', None]): + parser.exit( + 1, ('Workspace must be defined at the command line ' + 'or in the datastack file')) + else: + parsed_datastack.args['workspace_dir'] = args.workspace + + target_model = model_metadata.MODEL_METADATA[args.model].pyname + model_module = importlib.import_module(name=target_model) + LOGGER.info('Imported target %s from %s', + model_module.__name__, model_module) + + with utils.prepare_workspace(parsed_datastack.args['workspace_dir'], + name=parsed_datastack.model_name, + logging_level=log_level): + LOGGER.log(datastack.ARGS_LOG_LEVEL, + 'Starting model with parameters: \n%s', + datastack.format_args_dict(parsed_datastack.args, + parsed_datastack.model_name)) + + # We're deliberately not validating here because the user + # can just call ``invest validate `` to validate. + # + # Exceptions will already be logged to the logfile but will ALSO be + # written to stdout if this exception is uncaught. This is by + # design. + model_module.execute(parsed_datastack.args) + + if args.subcommand == 'serve': + ui_server.app.run(port=args.port) + parser.exit(0) + + if args.subcommand == 'export-py': + target_filepath = args.filepath + if not args.filepath: + target_filepath = f'{args.model}_execute.py' + export_to_python(target_filepath, args.model) + parser.exit() if __name__ == '__main__': diff --git a/src/natcap/invest/coastal_vulnerability.py b/src/natcap/invest/coastal_vulnerability.py index a1637451a6..7da6a1581e 100644 --- a/src/natcap/invest/coastal_vulnerability.py +++ b/src/natcap/invest/coastal_vulnerability.py @@ -1737,15 +1737,16 @@ def extract_bathymetry_along_ray( iy = int((point.y - bathy_gt[3]) / bathy_gt[5]) win_size = 1 - value = bathy_band.ReadAsArray( - xoff=ix, yoff=iy, - win_xsize=win_size, win_ysize=win_size) - if value is None: + try: + value = bathy_band.ReadAsArray( + xoff=ix, yoff=iy, + win_xsize=win_size, win_ysize=win_size) + except RuntimeError as ex: location = {'xoff': ix, 'yoff': iy, 'win_xsize': win_size, 'win_ysize': win_size} raise ValueError( - f'got a {value} when trying to read bathymetry at {location}. ' - 'Does the bathymetry input fully cover the fetch ray area?') + f'Failed to read bathymetry at {location}. Does the bathymetry ' + 'input fully cover the fetch ray area?') from ex if bathy_nodata is None or not numpy.isclose( value[0][0], bathy_nodata, equal_nan=True): bathy_values.append(value) @@ -2468,25 +2469,26 @@ def search_for_vector_habitat( geometry = feature.GetGeometryRef() if not geometry.IsValid(): - geometry = geometry.Buffer(0) # sometimes this fixes geometry - if geometry is not None: # geometry is None if the buffer failed. - clipped_geometry = geometry.Intersection(base_srs_clipping_geom) - if not clipped_geometry.IsEmpty(): - if target_spatial_reference != base_spatial_reference: - err_code = clipped_geometry.Transform(transform) - if err_code != 0: - LOGGER.warning( - f"Could not transform feature from " - f"{habitat_vector_path} to spatial reference " - "system of AOI") - continue - shapely_geom = shapely.wkb.loads( - bytes(clipped_geometry.ExportToWkb())) - shapely_geometry_list.extend(_list_geometry(shapely_geom)) - else: - LOGGER.warning( - f"FID {feature.GetFID()} in {habitat_vector_path} has invalid " - "geometry and will be excluded") + try: + geometry = geometry.Buffer(0) # sometimes this fixes geometry + except RuntimeError: + LOGGER.warning( + f"FID {feature.GetFID()} in {habitat_vector_path} has invalid " + "geometry and will be excluded") + continue + clipped_geometry = geometry.Intersection(base_srs_clipping_geom) + if not clipped_geometry.IsEmpty(): + if target_spatial_reference != base_spatial_reference: + err_code = clipped_geometry.Transform(transform) + if err_code != 0: + LOGGER.warning( + f"Could not transform feature from " + f"{habitat_vector_path} to spatial reference " + "system of AOI") + continue + shapely_geom = shapely.wkb.loads( + bytes(clipped_geometry.ExportToWkb())) + shapely_geometry_list.extend(_list_geometry(shapely_geom)) if not shapely_geometry_list: LOGGER.warning(f'No valid features exist in {habitat_vector_path}') diff --git a/src/natcap/invest/forest_carbon_edge_effect.py b/src/natcap/invest/forest_carbon_edge_effect.py index aa7a394ab8..9d18eb26af 100644 --- a/src/natcap/invest/forest_carbon_edge_effect.py +++ b/src/natcap/invest/forest_carbon_edge_effect.py @@ -782,14 +782,17 @@ def _build_spatial_index( # put all the polygons in the kd_tree because it's fast and simple for poly_feature in model_layer: poly_geom = poly_feature.GetGeometryRef() - poly_centroid = poly_geom.Centroid() - # put in row/col order since rasters are row/col indexed - kd_points.append([poly_centroid.GetY(), poly_centroid.GetX()]) - - theta_model_parameters.append([ - poly_feature.GetField(feature_id) for feature_id in - ['theta1', 'theta2', 'theta3']]) - method_model_parameter.append(poly_feature.GetField('method')) + if poly_geom.IsValid(): + poly_centroid = poly_geom.Centroid() + # put in row/col order since rasters are row/col indexed + kd_points.append([poly_centroid.GetY(), poly_centroid.GetX()]) + + theta_model_parameters.append([ + poly_feature.GetField(feature_id) for feature_id in + ['theta1', 'theta2', 'theta3']]) + method_model_parameter.append(poly_feature.GetField('method')) + else: + LOGGER.warning(f'skipping invalid geometry {poly_geom}') method_model_parameter = numpy.array( method_model_parameter, dtype=numpy.int32) diff --git a/src/natcap/invest/recreation/recmodel_client.py b/src/natcap/invest/recreation/recmodel_client.py index 5250eabbe9..7155af3f08 100644 --- a/src/natcap/invest/recreation/recmodel_client.py +++ b/src/natcap/invest/recreation/recmodel_client.py @@ -1603,26 +1603,18 @@ def _validate_same_projection(base_vector_path, table_path): invalid_projections = False for path in data_paths: - - def error_handler(err_level, err_no, err_msg): - """Empty error handler to avoid stderr output.""" - pass - gdal.PushErrorHandler(error_handler) - raster = gdal.OpenEx(path, gdal.OF_RASTER) - gdal.PopErrorHandler() - if raster is not None: + gis_type = pygeoprocessing.get_gis_type(path) + if gis_type == pygeoprocessing.UNKNOWN_TYPE: + return f"{path} did not load" + elif gis_type == pygeoprocessing.RASTER_TYPE: + raster = gdal.OpenEx(path, gdal.OF_RASTER) projection_as_str = raster.GetProjection() ref = osr.SpatialReference() ref.ImportFromWkt(projection_as_str) - raster = None else: vector = gdal.OpenEx(path, gdal.OF_VECTOR) - if vector is None: - return f"{path} did not load" layer = vector.GetLayer() ref = osr.SpatialReference(layer.GetSpatialRef().ExportToWkt()) - layer = None - vector = None if not base_ref.IsSame(ref): invalid_projections = True if invalid_projections: diff --git a/src/natcap/invest/utils.py b/src/natcap/invest/utils.py index dcae5734dd..dff0825a13 100644 --- a/src/natcap/invest/utils.py +++ b/src/natcap/invest/utils.py @@ -50,7 +50,9 @@ def _log_gdal_errors(*args, **kwargs): """Log error messages to osgeo. All error messages are logged with reasonable ``logging`` levels based - on the GDAL error level. + on the GDAL error level. While we are now using ``gdal.UseExceptions()``, + we still need this to handle GDAL logging that does not get raised as + an exception. Note: This function is designed to accept any number of positional and diff --git a/src/natcap/invest/validation.py b/src/natcap/invest/validation.py index d6f7df05fc..a040148375 100644 --- a/src/natcap/invest/validation.py +++ b/src/natcap/invest/validation.py @@ -304,19 +304,16 @@ def check_raster(filepath, projected=False, projection_units=None, **kwargs): if file_warning: return file_warning - gdal.PushErrorHandler('CPLQuietErrorHandler') - gdal_dataset = gdal.OpenEx(filepath, gdal.OF_RASTER) - gdal.PopErrorHandler() - - if gdal_dataset is None: + try: + gdal_dataset = gdal.OpenEx(filepath, gdal.OF_RASTER) + except RuntimeError: return MESSAGES['NOT_GDAL_RASTER'] + # Check that an overview .ovr file wasn't opened. if os.path.splitext(filepath)[1] == '.ovr': return MESSAGES['OVR_FILE'] - srs = osr.SpatialReference() - srs.ImportFromWkt(gdal_dataset.GetProjection()) - + srs = gdal_dataset.GetSpatialRef() projection_warning = _check_projection(srs, projected, projection_units) if projection_warning: gdal_dataset = None @@ -378,9 +375,10 @@ def check_vector(filepath, geometries, fields=None, projected=False, if file_warning: return file_warning - gdal.PushErrorHandler('CPLQuietErrorHandler') - gdal_dataset = gdal.OpenEx(filepath, gdal.OF_VECTOR) - gdal.PopErrorHandler() + try: + gdal_dataset = gdal.OpenEx(filepath, gdal.OF_VECTOR) + except RuntimeError: + return MESSAGES['NOT_GDAL_VECTOR'] geom_map = { 'POINT': [ogr.wkbPoint, ogr.wkbPointM, ogr.wkbPointZM, @@ -402,9 +400,6 @@ def check_vector(filepath, geometries, fields=None, projected=False, for geom in geometries: allowed_geom_types += geom_map[geom] - if gdal_dataset is None: - return MESSAGES['NOT_GDAL_VECTOR'] - # NOTE: this only checks the layer geometry type, not the types of the # actual geometries (layer.GetGeometryTypes()). This is probably equivalent # in most cases, and it's more efficient than checking every geometry, but diff --git a/src/natcap/invest/wave_energy.py b/src/natcap/invest/wave_energy.py index be91ea8391..e345a5732f 100644 --- a/src/natcap/invest/wave_energy.py +++ b/src/natcap/invest/wave_energy.py @@ -1148,23 +1148,18 @@ def _copy_vector_or_raster(base_file_path, target_file_path): ValueError if the base file can't be opened by GDAL. """ - # Open the file as raster first - source_dataset = gdal.OpenEx(base_file_path, gdal.OF_RASTER) - target_driver_name = _RASTER_DRIVER_NAME - if source_dataset is None: - # File didn't open as a raster; assume it's a vector + gis_type = pygeoprocessing.get_gis_type(base_file_path) + if gis_type == pygeoprocessing.RASTER_TYPE: + source_dataset = gdal.OpenEx(base_file_path, gdal.OF_RASTER) + target_driver_name = _RASTER_DRIVER_NAME + elif gis_type == pygeoprocessing.VECTOR_TYPE: source_dataset = gdal.OpenEx(base_file_path, gdal.OF_VECTOR) target_driver_name = _VECTOR_DRIVER_NAME - - # Raise an exception if the file can't be opened by GDAL - if source_dataset is None: - raise ValueError( - 'File %s is neither a GDAL-compatible raster nor vector.' - % base_file_path) - + else: + raise ValueError(f'File {base_file_path} is neither a GDAL-compatible ' + 'raster nor vector.') driver = gdal.GetDriverByName(target_driver_name) driver.CreateCopy(target_file_path, source_dataset) - source_dataset = None def _interpolate_vector_field_onto_raster( diff --git a/src/natcap/invest/wind_energy.py b/src/natcap/invest/wind_energy.py index 252e4811db..f02719dfc1 100644 --- a/src/natcap/invest/wind_energy.py +++ b/src/natcap/invest/wind_energy.py @@ -1846,7 +1846,7 @@ def _dist_mask_op(dist_arr): def _create_distance_raster(base_raster_path, base_vector_path, - target_dist_raster_path, work_dir): + target_dist_raster_path, work_dir, where_clause=None): """Create and rasterize vector onto a raster, and calculate dist transform. Create a raster where the pixel values represent the euclidean distance to @@ -1858,6 +1858,9 @@ def _create_distance_raster(base_raster_path, base_vector_path, base_vector_path (str): path to vector to be rasterized. target_dist_raster_path (str): path to raster with distance transform. work_dir (str): path to create a temp folder for saving files. + where_clause (str): If not None, is an SQL query-like string to filter + which features are rasterized. This kwarg is passed to + ``pygeoprocessing.rasterize``. Returns: None @@ -1885,7 +1888,8 @@ def _create_distance_raster(base_raster_path, base_vector_path, base_vector_path, rasterized_raster_path, burn_values=[1], - option_list=["ALL_TOUCHED=TRUE"]) + option_list=["ALL_TOUCHED=TRUE"], + where_clause=where_clause) # Calculate euclidean distance transform pygeoprocessing.distance_transform_edt( @@ -2590,67 +2594,25 @@ def _calculate_distances_land_grid(base_point_vector_path, base_raster_path, # A list to hold the land to grid distances in order for each point # features 'L2G' field l2g_dist = [] - # A list to hold the individual distance transform path's in order + # A list to hold the individual distance transform paths in order land_point_dist_raster_path_list = [] - # Get the original layer definition which holds needed attribute values - base_layer_defn = base_point_layer.GetLayerDefn() - file_ext, driver_name = _get_file_ext_and_driver_name( - base_point_vector_path) - output_driver = ogr.GetDriverByName(driver_name) - single_feature_vector_path = os.path.join( - temp_dir, 'single_feature' + file_ext) - target_vector = output_driver.CreateDataSource(single_feature_vector_path) - - # Create the new layer for target_vector using same name and - # geometry type from base_vector as well as spatial reference - target_layer = target_vector.CreateLayer(base_layer_defn.GetName(), - base_point_layer.GetSpatialRef(), - base_layer_defn.GetGeomType()) - - # Get the number of fields in original_layer - base_field_count = base_layer_defn.GetFieldCount() - - # For every field, create a duplicate field and add it to the new - # shapefiles layer - for fld_index in range(base_field_count): - base_field = base_layer_defn.GetFieldDefn(fld_index) - target_field = ogr.FieldDefn(base_field.GetName(), - base_field.GetType()) - # NOT setting the WIDTH or PRECISION because that seems to be - # unneeded and causes interesting OGR conflicts - target_layer.CreateField(target_field) - + fid_field = base_point_layer.GetFIDColumn() + if not fid_field: + fid_field = 'FID' # Create a new shapefile with only one feature to burn onto a raster # in order to get the distance transform based on that one feature for feature_index, point_feature in enumerate(base_point_layer): # Get the point features land to grid value and add it to the list - field_index = point_feature.GetFieldIndex('L2G') - l2g_dist.append(float(point_feature.GetField(field_index))) - - # Copy original_datasource's feature and set as new shapes feature - output_feature = ogr.Feature(feature_def=target_layer.GetLayerDefn()) - - # Since the original feature is of interest add its fields and - # Values to the new feature from the intersecting geometries - # The False in SetFrom() signifies that the fields must match - # exactly - output_feature.SetFrom(point_feature, False) - target_layer.CreateFeature(output_feature) - target_vector.SyncToDisk() - target_layer.DeleteFeature(point_feature.GetFID()) - - dist_raster_path = os.path.join(temp_dir, - 'dist_%s.tif' % feature_index) - _create_distance_raster(base_raster_path, single_feature_vector_path, - dist_raster_path, work_dir) + l2g_dist.append(float(point_feature.GetField('L2G'))) + + dist_raster_path = os.path.join(temp_dir, f'dist_{feature_index}.tif') + _create_distance_raster( + base_raster_path, base_point_vector_path, dist_raster_path, + work_dir, where_clause=f'{fid_field}={point_feature.GetFID()}') # Add each features distance transform result to list land_point_dist_raster_path_list.append(dist_raster_path) - target_layer = None - target_vector = None - base_point_layer = None - base_point_vector = None l2g_dist_array = numpy.array(l2g_dist) def _min_land_ocean_dist(*grid_distances): diff --git a/tests/test_annual_water_yield.py b/tests/test_annual_water_yield.py index fcfafbc292..e450f4b7e6 100644 --- a/tests/test_annual_water_yield.py +++ b/tests/test_annual_water_yield.py @@ -6,13 +6,14 @@ import pandas import numpy +from osgeo import gdal import pygeoprocessing REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'annual_water_yield') SAMPLE_DATA = os.path.join(REGRESSION_DATA, 'input') - +gdal.UseExceptions() class AnnualWaterYieldTests(unittest.TestCase): """Regression Tests for Annual Water Yield Model.""" diff --git a/tests/test_carbon.py b/tests/test_carbon.py index 746c69e983..e6c3486ca1 100644 --- a/tests/test_carbon.py +++ b/tests/test_carbon.py @@ -12,6 +12,7 @@ import numpy.testing import pygeoprocessing +gdal.UseExceptions() def make_simple_raster(base_raster_path, fill_val, nodata_val): """Create a 10x10 raster on designated path with fill value. diff --git a/tests/test_cli.py b/tests/test_cli.py index 038ce5b0f1..0d9bf63704 100644 --- a/tests/test_cli.py +++ b/tests/test_cli.py @@ -10,12 +10,13 @@ import importlib import uuid - try: from StringIO import StringIO except ImportError: from io import StringIO +from osgeo import gdal +gdal.UseExceptions() @contextlib.contextmanager def redirect_stdout(): diff --git a/tests/test_coastal_blue_carbon.py b/tests/test_coastal_blue_carbon.py index 10c983144f..27999bbb8c 100644 --- a/tests/test_coastal_blue_carbon.py +++ b/tests/test_coastal_blue_carbon.py @@ -17,6 +17,7 @@ from osgeo import gdal from osgeo import osr +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'coastal_blue_carbon') diff --git a/tests/test_coastal_vulnerability.py b/tests/test_coastal_vulnerability.py index a6e6f60887..f3e1edab30 100644 --- a/tests/test_coastal_vulnerability.py +++ b/tests/test_coastal_vulnerability.py @@ -19,7 +19,10 @@ from shapely.geometry import MultiPolygon from shapely.geometry import Point from shapely.geometry import Polygon +import logging +import sys +# gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'coastal_vulnerability') @@ -1744,39 +1747,39 @@ def make_vector_of_invalid_geoms(target_vector_path): 'POLYGON((0 0, 10 0, 10 10, 0 10, 0 0),(5 2,5 7,10 7, 10 2, 5 2))') assert not invalid_shared_edge_polygon.IsValid() - # 3: Dangling edge - fixed by buffer - dangle_geom = ('POLYGON((100 100, 110 100, 115 105, 110 100, 110 110, ' - '100 110, 100 100))') - invalid_dangling_edge_polygon = ogr.CreateGeometryFromWkt(dangle_geom) - assert not invalid_dangling_edge_polygon.IsValid() - - # One invalid geom that cannot be loaded by shapely or fixed by buffer - # We expect this polygon to be skipped by the CV functions being tested. - # 4: invalid open ring polygon - invalid_open_ring_polygon = ogr.CreateGeometryFromWkt( - 'POLYGON ((2 -2, 6 -2, 6 -6, 2 -6))') - assert not invalid_open_ring_polygon.IsValid() - - gpkg_driver = gdal.GetDriverByName('GPKG') - srs = osr.SpatialReference() - srs.ImportFromEPSG(32731) # WGS84/UTM zone 31s - target_vector = gpkg_driver.Create( - target_vector_path, 0, 0, 0, gdal.GDT_Unknown) - target_layer = target_vector.CreateLayer( - 'target_layer', srs, ogr.wkbUnknown) - - target_layer.StartTransaction() - input_geom_list = [invalid_bowtie_polygon, - invalid_shared_edge_polygon, - invalid_dangling_edge_polygon, - invalid_open_ring_polygon] - for geometry in input_geom_list: - outflow_feature = ogr.Feature(target_layer.GetLayerDefn()) - outflow_feature.SetGeometry(geometry) - target_layer.CreateFeature(outflow_feature) - target_layer.CommitTransaction() - - target_layer = None - target_vector = None - - return len(input_geom_list) + # # 3: Dangling edge - fixed by buffer + # dangle_geom = ('POLYGON((100 100, 110 100, 115 105, 110 100, 110 110, ' + # '100 110, 100 100))') + # invalid_dangling_edge_polygon = ogr.CreateGeometryFromWkt(dangle_geom) + # assert not invalid_dangling_edge_polygon.IsValid() + + # # One invalid geom that cannot be loaded by shapely or fixed by buffer + # # We expect this polygon to be skipped by the CV functions being tested. + # # 4: invalid open ring polygon + # invalid_open_ring_polygon = ogr.CreateGeometryFromWkt( + # 'POLYGON ((2 -2, 6 -2, 6 -6, 2 -6))') + # assert not invalid_open_ring_polygon.IsValid() + + # gpkg_driver = gdal.GetDriverByName('GPKG') + # srs = osr.SpatialReference() + # srs.ImportFromEPSG(32731) # WGS84/UTM zone 31s + # target_vector = gpkg_driver.Create( + # target_vector_path, 0, 0, 0, gdal.GDT_Unknown) + # target_layer = target_vector.CreateLayer( + # 'target_layer', srs, ogr.wkbUnknown) + + # target_layer.StartTransaction() + # input_geom_list = [invalid_bowtie_polygon, + # invalid_shared_edge_polygon, + # invalid_dangling_edge_polygon, + # invalid_open_ring_polygon] + # for geometry in input_geom_list: + # outflow_feature = ogr.Feature(target_layer.GetLayerDefn()) + # outflow_feature.SetGeometry(geometry) + # target_layer.CreateFeature(outflow_feature) + # target_layer.CommitTransaction() + + # target_layer = None + # target_vector = None + + # return len(input_geom_list) diff --git a/tests/test_crop_production.py b/tests/test_crop_production.py index 5afa0ca617..71ed3170a3 100644 --- a/tests/test_crop_production.py +++ b/tests/test_crop_production.py @@ -9,6 +9,7 @@ import pandas import pygeoprocessing +gdal.UseExceptions() MODEL_DATA_PATH = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'crop_production_model', 'model_data') diff --git a/tests/test_datastack.py b/tests/test_datastack.py index 35d0695fa7..0e65dcdd2b 100644 --- a/tests/test_datastack.py +++ b/tests/test_datastack.py @@ -18,6 +18,7 @@ from osgeo import gdal from osgeo import ogr +gdal.UseExceptions() _TEST_FILE_CWD = os.path.dirname(os.path.abspath(__file__)) DATA_DIR = os.path.join(_TEST_FILE_CWD, '..', 'data', 'invest-test-data', 'data_stack') diff --git a/tests/test_delineateit.py b/tests/test_delineateit.py index 897a20661e..9915d71e3e 100644 --- a/tests/test_delineateit.py +++ b/tests/test_delineateit.py @@ -19,6 +19,7 @@ from shapely.geometry import MultiPoint from shapely.geometry import Point +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'delineateit') diff --git a/tests/test_forest_carbon_edge.py b/tests/test_forest_carbon_edge.py index 3f2d0ac2a5..cacbd13ae6 100644 --- a/tests/test_forest_carbon_edge.py +++ b/tests/test_forest_carbon_edge.py @@ -7,7 +7,7 @@ from osgeo import gdal import numpy - +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'forest_carbon_edge_effect') diff --git a/tests/test_habitat_quality.py b/tests/test_habitat_quality.py index 2359cfeef1..143d113668 100644 --- a/tests/test_habitat_quality.py +++ b/tests/test_habitat_quality.py @@ -12,6 +12,7 @@ from osgeo import osr from shapely.geometry import Polygon +gdal.UseExceptions() def make_raster_from_array( base_array, base_raster_path, nodata_val=-1, gdal_type=gdal.GDT_Int32): diff --git a/tests/test_hra.py b/tests/test_hra.py index f0581261c5..946c878ff4 100644 --- a/tests/test_hra.py +++ b/tests/test_hra.py @@ -18,6 +18,7 @@ from osgeo import ogr from osgeo import osr +gdal.UseExceptions() ORIGIN = (1180000.0, 690000.0) _SRS = osr.SpatialReference() _SRS.ImportFromEPSG(26910) # UTM zone 10N diff --git a/tests/test_invest.py b/tests/test_invest.py index 27380ad464..50d820c77b 100644 --- a/tests/test_invest.py +++ b/tests/test_invest.py @@ -3,6 +3,8 @@ import unittest import os +from osgeo import gdal +gdal.UseExceptions() class FileRegistryTests(unittest.TestCase): """Tests for the InVEST file registry builder.""" diff --git a/tests/test_model_specs.py b/tests/test_model_specs.py index a0673fa92f..2518c1ab5e 100644 --- a/tests/test_model_specs.py +++ b/tests/test_model_specs.py @@ -4,7 +4,9 @@ import pint from natcap.invest.model_metadata import MODEL_METADATA +from osgeo import gdal +gdal.UseExceptions() valid_nested_types = { None: { # if no parent type (arg is top-level), then all types are valid 'boolean', diff --git a/tests/test_ndr.py b/tests/test_ndr.py index 5dc1bd456e..a719c7dd58 100644 --- a/tests/test_ndr.py +++ b/tests/test_ndr.py @@ -12,6 +12,7 @@ from osgeo import ogr from osgeo import osr +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'ndr') diff --git a/tests/test_pollination.py b/tests/test_pollination.py index 1897e9bff4..a734437856 100644 --- a/tests/test_pollination.py +++ b/tests/test_pollination.py @@ -7,9 +7,11 @@ import numpy import pygeoprocessing import shapely.geometry +from osgeo import gdal from osgeo import ogr from osgeo import osr +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'pollination') diff --git a/tests/test_recreation.py b/tests/test_recreation.py index 5992d55bc5..c4a515b0f4 100644 --- a/tests/test_recreation.py +++ b/tests/test_recreation.py @@ -28,6 +28,7 @@ from natcap.invest import utils +gdal.UseExceptions() Pyro4.config.SERIALIZER = 'marshal' # allow null bytes in strings REGRESSION_DATA = os.path.join( diff --git a/tests/test_routedem.py b/tests/test_routedem.py index bbadb4ce9f..85d34de3f8 100644 --- a/tests/test_routedem.py +++ b/tests/test_routedem.py @@ -9,6 +9,7 @@ from osgeo import gdal from osgeo import osr +gdal.UseExceptions() class RouteDEMTests(unittest.TestCase): """Tests for RouteDEM with Pygeoprocessing 1.x routing API.""" diff --git a/tests/test_scenario_proximity.py b/tests/test_scenario_proximity.py index 002a673a63..e8ed1ccb75 100644 --- a/tests/test_scenario_proximity.py +++ b/tests/test_scenario_proximity.py @@ -5,7 +5,9 @@ import os import pandas +from osgeo import gdal +gdal.UseExceptions() TEST_DATA_DIR = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'scenario_gen_proximity') diff --git a/tests/test_scenic_quality.py b/tests/test_scenic_quality.py index 398442f890..c99afdb4f8 100644 --- a/tests/test_scenic_quality.py +++ b/tests/test_scenic_quality.py @@ -14,6 +14,7 @@ from shapely.geometry import Point from shapely.geometry import Polygon +gdal.UseExceptions() _SRS = osr.SpatialReference() _SRS.ImportFromEPSG(32731) # WGS84 / UTM zone 31s WKT = _SRS.ExportToWkt() diff --git a/tests/test_sdr.py b/tests/test_sdr.py index e509837eca..341076a085 100644 --- a/tests/test_sdr.py +++ b/tests/test_sdr.py @@ -9,6 +9,7 @@ from osgeo import gdal from osgeo import osr +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'sdr') SAMPLE_DATA = os.path.join(REGRESSION_DATA, 'input') diff --git a/tests/test_seasonal_water_yield_regression.py b/tests/test_seasonal_water_yield_regression.py index e5eafa0e98..e795d85999 100644 --- a/tests/test_seasonal_water_yield_regression.py +++ b/tests/test_seasonal_water_yield_regression.py @@ -10,6 +10,7 @@ from osgeo import ogr from osgeo import osr +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'seasonal_water_yield') diff --git a/tests/test_spec_utils.py b/tests/test_spec_utils.py index 997c7c4b74..977a4d95c4 100644 --- a/tests/test_spec_utils.py +++ b/tests/test_spec_utils.py @@ -2,7 +2,9 @@ from natcap.invest import spec_utils from natcap.invest.unit_registry import u +from osgeo import gdal +gdal.UseExceptions() class TestSpecUtils(unittest.TestCase): diff --git a/tests/test_stormwater.py b/tests/test_stormwater.py index dbf6f7e442..36d8bf6c6f 100644 --- a/tests/test_stormwater.py +++ b/tests/test_stormwater.py @@ -13,7 +13,7 @@ from pygeoprocessing.geoprocessing_core import ( DEFAULT_GTIFF_CREATION_TUPLE_OPTIONS as opts_tuple) - +gdal.UseExceptions() TEST_DATA = os.path.join(os.path.dirname( __file__), '..', 'data', 'invest-test-data', 'stormwater') diff --git a/tests/test_translation.py b/tests/test_translation.py index 2606473e7a..174f42d144 100644 --- a/tests/test_translation.py +++ b/tests/test_translation.py @@ -10,7 +10,9 @@ from babel.messages import Catalog, mofile import natcap.invest from natcap.invest import validation +from osgeo import gdal +gdal.UseExceptions() TEST_LANG = 'll' # assign to local variable so that it won't be changed by translation diff --git a/tests/test_ucm.py b/tests/test_ucm.py index ea6ef583b7..5fdeaed7e2 100644 --- a/tests/test_ucm.py +++ b/tests/test_ucm.py @@ -8,6 +8,7 @@ import pandas from osgeo import gdal +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'ucm') diff --git a/tests/test_ufrm.py b/tests/test_ufrm.py index eb2cef2f6a..fe3e58bf4b 100644 --- a/tests/test_ufrm.py +++ b/tests/test_ufrm.py @@ -13,6 +13,7 @@ from osgeo import ogr from osgeo import osr +gdal.UseExceptions() class UFRMTests(unittest.TestCase): """Tests for the Urban Flood Risk Mitigation Model.""" diff --git a/tests/test_ui_server.py b/tests/test_ui_server.py index 78cc86cd01..5d47586f41 100644 --- a/tests/test_ui_server.py +++ b/tests/test_ui_server.py @@ -6,7 +6,9 @@ from unittest.mock import Mock, patch from natcap.invest import ui_server +from osgeo import gdal +gdal.UseExceptions() TEST_DATA_PATH = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data') diff --git a/tests/test_urban_nature_access.py b/tests/test_urban_nature_access.py index a3d3d7b43c..e70f379db0 100644 --- a/tests/test_urban_nature_access.py +++ b/tests/test_urban_nature_access.py @@ -18,6 +18,7 @@ from osgeo import ogr from osgeo import osr +gdal.UseExceptions() _DEFAULT_ORIGIN = (444720, 3751320) _DEFAULT_PIXEL_SIZE = (30, -30) _DEFAULT_EPSG = 3116 diff --git a/tests/test_usage_logging.py b/tests/test_usage_logging.py index 98b0d93d94..f459d6a87b 100644 --- a/tests/test_usage_logging.py +++ b/tests/test_usage_logging.py @@ -13,6 +13,7 @@ import numpy import numpy.testing +gdal.UseExceptions() class UsageLoggingTests(unittest.TestCase): """Tests for the InVEST usage logging framework.""" diff --git a/tests/test_utils.py b/tests/test_utils.py index 6025e699b6..7a7b3a55ad 100644 --- a/tests/test_utils.py +++ b/tests/test_utils.py @@ -25,6 +25,7 @@ from shapely.geometry import Point from shapely.geometry import Polygon +gdal.UseExceptions() class SuffixUtilsTests(unittest.TestCase): """Tests for natcap.invest.utils.make_suffix_string.""" @@ -412,17 +413,22 @@ def test_log_warnings(self): logfile = os.path.join(self.workspace, 'logfile.txt') - # this warning should go to stdout. - gdal.Open('this_file_should_not_exist.tif') + invalid_polygon = ogr.CreateGeometryFromWkt( + 'POLYGON ((-20 -20, -16 -20, -20 -16, -16 -16, -20 -20))') + + # This produces a GDAL warning that does not raise an + # exception with UseExceptions(). Without capture_gdal_logging, + # it will be printed directly to stderr + invalid_polygon.IsValid() with utils.log_to_file(logfile) as handler: with utils.capture_gdal_logging(): # warning should be captured. - gdal.Open('file_file_should_also_not_exist.tif') + invalid_polygon.IsValid() handler.flush() - # warning should go to stdout - gdal.Open('this_file_should_not_exist.tif') + # warning should go to stderr + invalid_polygon.IsValid() with open(logfile) as opened_logfile: messages = [msg for msg in opened_logfile.read().split('\n') @@ -499,7 +505,11 @@ def test_prepare_workspace(self): with utils.prepare_workspace(workspace, 'some_model'): warnings.warn('deprecated', UserWarning) - gdal.Open('file should not exist') + invalid_polygon = ogr.CreateGeometryFromWkt( + 'POLYGON ((-20 -20, -16 -20, -20 -16, -16 -16, -20 -20))') + # This produces a GDAL warning that does not raise an + # exception with UseExceptions() + invalid_polygon.IsValid() self.assertTrue(os.path.exists(workspace)) logfile_glob = glob.glob(os.path.join(workspace, '*.txt')) @@ -509,11 +519,9 @@ def test_prepare_workspace(self): with open(logfile_glob[0]) as logfile: logfile_text = logfile.read() # all the following strings should be in the logfile. - expected_string = ( - 'file should not exist: No such file or directory') - self.assertTrue( - expected_string in logfile_text) # gdal error captured - self.assertEqual(len(re.findall('WARNING', logfile_text)), 1) + self.assertTrue( # gdal logging captured + 'Self-intersection at or near point -18 -18' in logfile_text) + self.assertEqual(len(re.findall('WARNING', logfile_text)), 2) self.assertTrue('Elapsed time:' in logfile_text) diff --git a/tests/test_validation.py b/tests/test_validation.py index f5ad094f50..038d4f3f96 100644 --- a/tests/test_validation.py +++ b/tests/test_validation.py @@ -18,6 +18,7 @@ from osgeo import ogr from osgeo import osr +gdal.UseExceptions() class SpatialOverlapTest(unittest.TestCase): """Test Spatial Overlap.""" diff --git a/tests/test_wave_energy.py b/tests/test_wave_energy.py index 99e85a9a1a..31dd6a6c3e 100644 --- a/tests/test_wave_energy.py +++ b/tests/test_wave_energy.py @@ -18,6 +18,7 @@ from natcap.invest import utils import pygeoprocessing +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'wave_energy') SAMPLE_DATA = os.path.join(REGRESSION_DATA, 'input') diff --git a/tests/test_wind_energy.py b/tests/test_wind_energy.py index 209da2f814..5889e65e97 100644 --- a/tests/test_wind_energy.py +++ b/tests/test_wind_energy.py @@ -17,6 +17,7 @@ import pygeoprocessing +gdal.UseExceptions() SAMPLE_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'wind_energy', 'input') From 579b0aa324bab3e008047c56dcb49d9ce4152fba Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 19 Nov 2024 13:51:58 -0800 Subject: [PATCH 65/90] cleanup --- src/natcap/invest/cli.py | 504 ++++++++++++++-------------- tests/test_coastal_vulnerability.py | 76 ++--- 2 files changed, 288 insertions(+), 292 deletions(-) diff --git a/src/natcap/invest/cli.py b/src/natcap/invest/cli.py index 27c8ae8f60..c4ff04829a 100644 --- a/src/natcap/invest/cli.py +++ b/src/natcap/invest/cli.py @@ -19,7 +19,6 @@ from natcap.invest import spec_utils from natcap.invest import ui_server from natcap.invest import utils -from pygeoprocessing.geoprocessing_core import GDALUseExceptions DEFAULT_EXIT_CODE = 1 @@ -219,268 +218,267 @@ def main(user_args=None): so models may be run in this way without having GUI packages installed. """ - with GDALUseExceptions(): - parser = argparse.ArgumentParser( - description=( - 'Integrated Valuation of Ecosystem Services and Tradeoffs. ' - 'InVEST (Integrated Valuation of Ecosystem Services and ' - 'Tradeoffs) is a family of tools for quantifying the values of ' - 'natural capital in clear, credible, and practical ways. In ' - 'promising a return (of societal benefits) on investments in ' - 'nature, the scientific community needs to deliver knowledge and ' - 'tools to quantify and forecast this return. InVEST enables ' - 'decision-makers to quantify the importance of natural capital, ' - 'to assess the tradeoffs associated with alternative choices, ' - 'and to integrate conservation and human development. \n\n' - 'Older versions of InVEST ran as script tools in the ArcGIS ' - 'ArcToolBox environment, but have almost all been ported over to ' - 'a purely open-source python environment.'), - prog='invest' - ) - parser.add_argument('--version', action='version', - version=natcap.invest.__version__) - verbosity_group = parser.add_mutually_exclusive_group() - verbosity_group.add_argument( - '-v', '--verbose', dest='verbosity', default=0, action='count', - help=('Increase verbosity. Affects how much logging is printed to ' - 'the console and (if running in headless mode) how much is ' - 'written to the logfile.')) - verbosity_group.add_argument( - '--debug', dest='log_level', default=logging.ERROR, - action='store_const', const=logging.DEBUG, - help='Enable debug logging. Alias for -vvv') - - parser.add_argument( - '--taskgraph-log-level', dest='taskgraph_log_level', default='ERROR', - type=str, choices=['DEBUG', 'INFO', 'WARNING', 'ERROR'], - help=('Set the logging level for Taskgraph. Affects how much logging ' - 'Taskgraph prints to the console and (if running in headless ' - 'mode) how much is written to the logfile.')) - - # list the language code and corresponding language name (in that language) - supported_languages_string = ', '.join([ - f'{locale} ({display_name})' - for locale, display_name in natcap.invest.LOCALE_NAME_MAP.items()]) - parser.add_argument( - '-L', '--language', default='en', - choices=natcap.invest.LOCALES, - help=('Choose a language. Model specs, names, and validation messages ' - 'will be translated. Log messages are not translated. Value ' - 'should be an ISO 639-1 language code. Supported options are: ' - f'{supported_languages_string}.')) - - subparsers = parser.add_subparsers(dest='subcommand') - - listmodels_subparser = subparsers.add_parser( - 'list', help='List the available InVEST models') - listmodels_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - - run_subparser = subparsers.add_parser( - 'run', help='Run an InVEST model') - # Recognize '--headless' for backwards compatibility. - # This arg is otherwise unused. - run_subparser.add_argument( - '-l', '--headless', action='store_true', - help=argparse.SUPPRESS) - run_subparser.add_argument( - '-d', '--datastack', default=None, nargs='?', - help=('Run the specified model with this JSON datastack. ' - 'Required if using --headless')) - run_subparser.add_argument( - '-w', '--workspace', default=None, nargs='?', - help=('The workspace in which outputs will be saved. ' - 'Required if using --headless')) - run_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model to run. Use "invest list" to list the available ' - 'models.')) - - validate_subparser = subparsers.add_parser( - 'validate', help=( - 'Validate the parameters of a datastack')) - validate_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - validate_subparser.add_argument( - 'datastack', help=('Path to a JSON datastack.')) - - getspec_subparser = subparsers.add_parser( - 'getspec', help=('Get the specification of a model.')) - getspec_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - getspec_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model for which the spec should be fetched. Use "invest ' - 'list" to list the available models.')) - - serve_subparser = subparsers.add_parser( - 'serve', help=('Start the flask app on the localhost.')) - serve_subparser.add_argument( - '--port', type=int, default=56789, - help='Port number for the Flask server') - - export_py_subparser = subparsers.add_parser( - 'export-py', help=('Save a python script that executes a model.')) - export_py_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model that the python script will execute. Use "invest ' - 'list" to list the available models.')) - export_py_subparser.add_argument( - '-f', '--filepath', default=None, - help='Define a location for the saved .py file') - - args = parser.parse_args(user_args) - natcap.invest.set_locale(args.language) - - root_logger = logging.getLogger() - handler = logging.StreamHandler(sys.stdout) - formatter = logging.Formatter( - fmt='%(asctime)s %(name)-18s %(levelname)-8s %(message)s', - datefmt='%m/%d/%Y %H:%M:%S ') - handler.setFormatter(formatter) - - # Set the log level based on what the user provides in the available - # arguments. Verbosity: the more v's the lower the logging threshold. - # If --debug is used, the logging threshold is 10. - # If the user goes lower than logging.DEBUG, default to logging.DEBUG. - log_level = min(args.log_level, logging.ERROR - (args.verbosity*10)) - handler.setLevel(max(log_level, logging.DEBUG)) # don't go below DEBUG - root_logger.addHandler(handler) - LOGGER.info('Setting handler log level to %s', log_level) - - # Set the log level for taskgraph. - taskgraph_log_level = logging.getLevelName(args.taskgraph_log_level.upper()) - logging.getLogger('taskgraph').setLevel(taskgraph_log_level) - LOGGER.debug('Setting taskgraph log level to %s', taskgraph_log_level) - - # FYI: Root logger by default has a level of logging.WARNING. - # To capture ALL logging produced in this system at runtime, use this: - # logging.getLogger().setLevel(logging.DEBUG) - # Also FYI: using logging.DEBUG means that the logger will defer to - # the setting of the parent logger. - logging.getLogger('natcap').setLevel(logging.DEBUG) - - if args.subcommand == 'list': - # reevaluate the model names in the new language - importlib.reload(model_metadata) - if args.json: - message = build_model_list_json() - else: - message = build_model_list_table() + parser = argparse.ArgumentParser( + description=( + 'Integrated Valuation of Ecosystem Services and Tradeoffs. ' + 'InVEST (Integrated Valuation of Ecosystem Services and ' + 'Tradeoffs) is a family of tools for quantifying the values of ' + 'natural capital in clear, credible, and practical ways. In ' + 'promising a return (of societal benefits) on investments in ' + 'nature, the scientific community needs to deliver knowledge and ' + 'tools to quantify and forecast this return. InVEST enables ' + 'decision-makers to quantify the importance of natural capital, ' + 'to assess the tradeoffs associated with alternative choices, ' + 'and to integrate conservation and human development. \n\n' + 'Older versions of InVEST ran as script tools in the ArcGIS ' + 'ArcToolBox environment, but have almost all been ported over to ' + 'a purely open-source python environment.'), + prog='invest' + ) + parser.add_argument('--version', action='version', + version=natcap.invest.__version__) + verbosity_group = parser.add_mutually_exclusive_group() + verbosity_group.add_argument( + '-v', '--verbose', dest='verbosity', default=0, action='count', + help=('Increase verbosity. Affects how much logging is printed to ' + 'the console and (if running in headless mode) how much is ' + 'written to the logfile.')) + verbosity_group.add_argument( + '--debug', dest='log_level', default=logging.ERROR, + action='store_const', const=logging.DEBUG, + help='Enable debug logging. Alias for -vvv') + + parser.add_argument( + '--taskgraph-log-level', dest='taskgraph_log_level', default='ERROR', + type=str, choices=['DEBUG', 'INFO', 'WARNING', 'ERROR'], + help=('Set the logging level for Taskgraph. Affects how much logging ' + 'Taskgraph prints to the console and (if running in headless ' + 'mode) how much is written to the logfile.')) + + # list the language code and corresponding language name (in that language) + supported_languages_string = ', '.join([ + f'{locale} ({display_name})' + for locale, display_name in natcap.invest.LOCALE_NAME_MAP.items()]) + parser.add_argument( + '-L', '--language', default='en', + choices=natcap.invest.LOCALES, + help=('Choose a language. Model specs, names, and validation messages ' + 'will be translated. Log messages are not translated. Value ' + 'should be an ISO 639-1 language code. Supported options are: ' + f'{supported_languages_string}.')) + + subparsers = parser.add_subparsers(dest='subcommand') + + listmodels_subparser = subparsers.add_parser( + 'list', help='List the available InVEST models') + listmodels_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + + run_subparser = subparsers.add_parser( + 'run', help='Run an InVEST model') + # Recognize '--headless' for backwards compatibility. + # This arg is otherwise unused. + run_subparser.add_argument( + '-l', '--headless', action='store_true', + help=argparse.SUPPRESS) + run_subparser.add_argument( + '-d', '--datastack', default=None, nargs='?', + help=('Run the specified model with this JSON datastack. ' + 'Required if using --headless')) + run_subparser.add_argument( + '-w', '--workspace', default=None, nargs='?', + help=('The workspace in which outputs will be saved. ' + 'Required if using --headless')) + run_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model to run. Use "invest list" to list the available ' + 'models.')) + + validate_subparser = subparsers.add_parser( + 'validate', help=( + 'Validate the parameters of a datastack')) + validate_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + validate_subparser.add_argument( + 'datastack', help=('Path to a JSON datastack.')) + + getspec_subparser = subparsers.add_parser( + 'getspec', help=('Get the specification of a model.')) + getspec_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + getspec_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model for which the spec should be fetched. Use "invest ' + 'list" to list the available models.')) + + serve_subparser = subparsers.add_parser( + 'serve', help=('Start the flask app on the localhost.')) + serve_subparser.add_argument( + '--port', type=int, default=56789, + help='Port number for the Flask server') + + export_py_subparser = subparsers.add_parser( + 'export-py', help=('Save a python script that executes a model.')) + export_py_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model that the python script will execute. Use "invest ' + 'list" to list the available models.')) + export_py_subparser.add_argument( + '-f', '--filepath', default=None, + help='Define a location for the saved .py file') + + args = parser.parse_args(user_args) + natcap.invest.set_locale(args.language) - sys.stdout.write(message) - parser.exit() + root_logger = logging.getLogger() + handler = logging.StreamHandler(sys.stdout) + formatter = logging.Formatter( + fmt='%(asctime)s %(name)-18s %(levelname)-8s %(message)s', + datefmt='%m/%d/%Y %H:%M:%S ') + handler.setFormatter(formatter) - if args.subcommand == 'validate': - try: - parsed_datastack = datastack.extract_parameter_set(args.datastack) - except Exception as error: - parser.exit( - 1, "Error when parsing JSON datastack:\n " + str(error)) - - # reload validation module first so it's also in the correct language - importlib.reload(importlib.import_module('natcap.invest.validation')) - model_module = importlib.reload(importlib.import_module( - name=parsed_datastack.model_name)) - - try: - validation_result = model_module.validate(parsed_datastack.args) - except KeyError as missing_keys_error: - if args.json: - message = json.dumps( - {'validation_results': { - str(list(missing_keys_error.args)): 'Key is missing'}}) - else: - message = ('Datastack is missing keys:\n ' + - str(missing_keys_error.args)) - - # Missing keys have an exit code of 1 because that would indicate - # probably programmer error. - sys.stdout.write(message) - parser.exit(1) - except Exception as error: - parser.exit( - 1, ('Datastack could not be validated:\n ' + - str(error))) + # Set the log level based on what the user provides in the available + # arguments. Verbosity: the more v's the lower the logging threshold. + # If --debug is used, the logging threshold is 10. + # If the user goes lower than logging.DEBUG, default to logging.DEBUG. + log_level = min(args.log_level, logging.ERROR - (args.verbosity*10)) + handler.setLevel(max(log_level, logging.DEBUG)) # don't go below DEBUG + root_logger.addHandler(handler) + LOGGER.info('Setting handler log level to %s', log_level) + + # Set the log level for taskgraph. + taskgraph_log_level = logging.getLevelName(args.taskgraph_log_level.upper()) + logging.getLogger('taskgraph').setLevel(taskgraph_log_level) + LOGGER.debug('Setting taskgraph log level to %s', taskgraph_log_level) + + # FYI: Root logger by default has a level of logging.WARNING. + # To capture ALL logging produced in this system at runtime, use this: + # logging.getLogger().setLevel(logging.DEBUG) + # Also FYI: using logging.DEBUG means that the logger will defer to + # the setting of the parent logger. + logging.getLogger('natcap').setLevel(logging.DEBUG) + + if args.subcommand == 'list': + # reevaluate the model names in the new language + importlib.reload(model_metadata) + if args.json: + message = build_model_list_json() + else: + message = build_model_list_table() - # Even validation errors will have an exit code of 0 - if args.json: - message = json.dumps({ - 'validation_results': validation_result}) - else: - message = pprint.pformat(validation_result) + sys.stdout.write(message) + parser.exit() - sys.stdout.write(message) - parser.exit(0) + if args.subcommand == 'validate': + try: + parsed_datastack = datastack.extract_parameter_set(args.datastack) + except Exception as error: + parser.exit( + 1, "Error when parsing JSON datastack:\n " + str(error)) - if args.subcommand == 'getspec': - target_model = model_metadata.MODEL_METADATA[args.model].pyname - model_module = importlib.reload( - importlib.import_module(name=target_model)) - spec = model_module.MODEL_SPEC + # reload validation module first so it's also in the correct language + importlib.reload(importlib.import_module('natcap.invest.validation')) + model_module = importlib.reload(importlib.import_module( + name=parsed_datastack.model_name)) + try: + validation_result = model_module.validate(parsed_datastack.args) + except KeyError as missing_keys_error: if args.json: - message = spec_utils.serialize_args_spec(spec) + message = json.dumps( + {'validation_results': { + str(list(missing_keys_error.args)): 'Key is missing'}}) else: - message = pprint.pformat(spec) + message = ('Datastack is missing keys:\n ' + + str(missing_keys_error.args)) + + # Missing keys have an exit code of 1 because that would indicate + # probably programmer error. sys.stdout.write(message) - parser.exit(0) - - if args.subcommand == 'run': - if args.headless: - warnings.warn( - '--headless (-l) is now the default (and only) behavior ' - 'for `invest run`. This flag will not be recognized ' - 'in the future.', FutureWarning, stacklevel=2) # 2 for brevity - if not args.datastack: - parser.exit(1, 'Datastack required for execution.') - - try: - parsed_datastack = datastack.extract_parameter_set(args.datastack) - except Exception as error: + parser.exit(1) + except Exception as error: + parser.exit( + 1, ('Datastack could not be validated:\n ' + + str(error))) + + # Even validation errors will have an exit code of 0 + if args.json: + message = json.dumps({ + 'validation_results': validation_result}) + else: + message = pprint.pformat(validation_result) + + sys.stdout.write(message) + parser.exit(0) + + if args.subcommand == 'getspec': + target_model = model_metadata.MODEL_METADATA[args.model].pyname + model_module = importlib.reload( + importlib.import_module(name=target_model)) + spec = model_module.MODEL_SPEC + + if args.json: + message = spec_utils.serialize_args_spec(spec) + else: + message = pprint.pformat(spec) + sys.stdout.write(message) + parser.exit(0) + + if args.subcommand == 'run': + if args.headless: + warnings.warn( + '--headless (-l) is now the default (and only) behavior ' + 'for `invest run`. This flag will not be recognized ' + 'in the future.', FutureWarning, stacklevel=2) # 2 for brevity + if not args.datastack: + parser.exit(1, 'Datastack required for execution.') + + try: + parsed_datastack = datastack.extract_parameter_set(args.datastack) + except Exception as error: + parser.exit( + 1, "Error when parsing JSON datastack:\n " + str(error)) + + if not args.workspace: + if ('workspace_dir' not in parsed_datastack.args or + parsed_datastack.args['workspace_dir'] in ['', None]): parser.exit( - 1, "Error when parsing JSON datastack:\n " + str(error)) - - if not args.workspace: - if ('workspace_dir' not in parsed_datastack.args or - parsed_datastack.args['workspace_dir'] in ['', None]): - parser.exit( - 1, ('Workspace must be defined at the command line ' - 'or in the datastack file')) - else: - parsed_datastack.args['workspace_dir'] = args.workspace - - target_model = model_metadata.MODEL_METADATA[args.model].pyname - model_module = importlib.import_module(name=target_model) - LOGGER.info('Imported target %s from %s', - model_module.__name__, model_module) - - with utils.prepare_workspace(parsed_datastack.args['workspace_dir'], - name=parsed_datastack.model_name, - logging_level=log_level): - LOGGER.log(datastack.ARGS_LOG_LEVEL, - 'Starting model with parameters: \n%s', - datastack.format_args_dict(parsed_datastack.args, - parsed_datastack.model_name)) - - # We're deliberately not validating here because the user - # can just call ``invest validate `` to validate. - # - # Exceptions will already be logged to the logfile but will ALSO be - # written to stdout if this exception is uncaught. This is by - # design. - model_module.execute(parsed_datastack.args) - - if args.subcommand == 'serve': - ui_server.app.run(port=args.port) - parser.exit(0) - - if args.subcommand == 'export-py': - target_filepath = args.filepath - if not args.filepath: - target_filepath = f'{args.model}_execute.py' - export_to_python(target_filepath, args.model) - parser.exit() + 1, ('Workspace must be defined at the command line ' + 'or in the datastack file')) + else: + parsed_datastack.args['workspace_dir'] = args.workspace + + target_model = model_metadata.MODEL_METADATA[args.model].pyname + model_module = importlib.import_module(name=target_model) + LOGGER.info('Imported target %s from %s', + model_module.__name__, model_module) + + with utils.prepare_workspace(parsed_datastack.args['workspace_dir'], + name=parsed_datastack.model_name, + logging_level=log_level): + LOGGER.log(datastack.ARGS_LOG_LEVEL, + 'Starting model with parameters: \n%s', + datastack.format_args_dict(parsed_datastack.args, + parsed_datastack.model_name)) + + # We're deliberately not validating here because the user + # can just call ``invest validate `` to validate. + # + # Exceptions will already be logged to the logfile but will ALSO be + # written to stdout if this exception is uncaught. This is by + # design. + model_module.execute(parsed_datastack.args) + + if args.subcommand == 'serve': + ui_server.app.run(port=args.port) + parser.exit(0) + + if args.subcommand == 'export-py': + target_filepath = args.filepath + if not args.filepath: + target_filepath = f'{args.model}_execute.py' + export_to_python(target_filepath, args.model) + parser.exit() if __name__ == '__main__': diff --git a/tests/test_coastal_vulnerability.py b/tests/test_coastal_vulnerability.py index f3e1edab30..cb290a0865 100644 --- a/tests/test_coastal_vulnerability.py +++ b/tests/test_coastal_vulnerability.py @@ -19,10 +19,8 @@ from shapely.geometry import MultiPolygon from shapely.geometry import Point from shapely.geometry import Polygon -import logging -import sys -# gdal.UseExceptions() +gdal.UseExceptions() REGRESSION_DATA = os.path.join( os.path.dirname(__file__), '..', 'data', 'invest-test-data', 'coastal_vulnerability') @@ -1747,39 +1745,39 @@ def make_vector_of_invalid_geoms(target_vector_path): 'POLYGON((0 0, 10 0, 10 10, 0 10, 0 0),(5 2,5 7,10 7, 10 2, 5 2))') assert not invalid_shared_edge_polygon.IsValid() - # # 3: Dangling edge - fixed by buffer - # dangle_geom = ('POLYGON((100 100, 110 100, 115 105, 110 100, 110 110, ' - # '100 110, 100 100))') - # invalid_dangling_edge_polygon = ogr.CreateGeometryFromWkt(dangle_geom) - # assert not invalid_dangling_edge_polygon.IsValid() - - # # One invalid geom that cannot be loaded by shapely or fixed by buffer - # # We expect this polygon to be skipped by the CV functions being tested. - # # 4: invalid open ring polygon - # invalid_open_ring_polygon = ogr.CreateGeometryFromWkt( - # 'POLYGON ((2 -2, 6 -2, 6 -6, 2 -6))') - # assert not invalid_open_ring_polygon.IsValid() - - # gpkg_driver = gdal.GetDriverByName('GPKG') - # srs = osr.SpatialReference() - # srs.ImportFromEPSG(32731) # WGS84/UTM zone 31s - # target_vector = gpkg_driver.Create( - # target_vector_path, 0, 0, 0, gdal.GDT_Unknown) - # target_layer = target_vector.CreateLayer( - # 'target_layer', srs, ogr.wkbUnknown) - - # target_layer.StartTransaction() - # input_geom_list = [invalid_bowtie_polygon, - # invalid_shared_edge_polygon, - # invalid_dangling_edge_polygon, - # invalid_open_ring_polygon] - # for geometry in input_geom_list: - # outflow_feature = ogr.Feature(target_layer.GetLayerDefn()) - # outflow_feature.SetGeometry(geometry) - # target_layer.CreateFeature(outflow_feature) - # target_layer.CommitTransaction() - - # target_layer = None - # target_vector = None - - # return len(input_geom_list) + # 3: Dangling edge - fixed by buffer + dangle_geom = ('POLYGON((100 100, 110 100, 115 105, 110 100, 110 110, ' + '100 110, 100 100))') + invalid_dangling_edge_polygon = ogr.CreateGeometryFromWkt(dangle_geom) + assert not invalid_dangling_edge_polygon.IsValid() + + # One invalid geom that cannot be loaded by shapely or fixed by buffer + # We expect this polygon to be skipped by the CV functions being tested. + # 4: invalid open ring polygon + invalid_open_ring_polygon = ogr.CreateGeometryFromWkt( + 'POLYGON ((2 -2, 6 -2, 6 -6, 2 -6))') + assert not invalid_open_ring_polygon.IsValid() + + gpkg_driver = gdal.GetDriverByName('GPKG') + srs = osr.SpatialReference() + srs.ImportFromEPSG(32731) # WGS84/UTM zone 31s + target_vector = gpkg_driver.Create( + target_vector_path, 0, 0, 0, gdal.GDT_Unknown) + target_layer = target_vector.CreateLayer( + 'target_layer', srs, ogr.wkbUnknown) + + target_layer.StartTransaction() + input_geom_list = [invalid_bowtie_polygon, + invalid_shared_edge_polygon, + invalid_dangling_edge_polygon, + invalid_open_ring_polygon] + for geometry in input_geom_list: + outflow_feature = ogr.Feature(target_layer.GetLayerDefn()) + outflow_feature.SetGeometry(geometry) + target_layer.CreateFeature(outflow_feature) + target_layer.CommitTransaction() + + target_layer = None + target_vector = None + + return len(input_geom_list) From 624ea43f6f718c5fd2338a41947723195a32eb77 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 19 Nov 2024 14:14:58 -0800 Subject: [PATCH 66/90] add futurewarning about gdal exceptions and use in cli --- src/natcap/invest/__init__.py | 10 + src/natcap/invest/cli.py | 520 +++++++++++++++++----------------- 2 files changed, 271 insertions(+), 259 deletions(-) diff --git a/src/natcap/invest/__init__.py b/src/natcap/invest/__init__.py index 3ecba007e0..3d73a90890 100644 --- a/src/natcap/invest/__init__.py +++ b/src/natcap/invest/__init__.py @@ -4,8 +4,10 @@ import os import sys from gettext import translation +import warnings import babel +from osgeo import gdal LOGGER = logging.getLogger('natcap.invest') LOGGER.addHandler(logging.NullHandler()) @@ -28,6 +30,14 @@ locale: babel.Locale(locale).display_name for locale in LOCALES } +if not gdal.GetUseExceptions(): + warnings.warn((''' + natcap.invest requires GDAL exceptions to be enabled. You must + call gdal.UseExceptions() to avoid unexpected behavior from + natcap.invest. A future version will enable exceptions on import. + gdal.UseExceptions() affects global state, so this may affect the + behavior of other packages.'''), FutureWarning) + def set_locale(locale_code): """Set the `gettext` attribute of natcap.invest. diff --git a/src/natcap/invest/cli.py b/src/natcap/invest/cli.py index c4ff04829a..6df99a470b 100644 --- a/src/natcap/invest/cli.py +++ b/src/natcap/invest/cli.py @@ -12,14 +12,15 @@ import textwrap import warnings -import natcap.invest -from natcap.invest import datastack -from natcap.invest import model_metadata -from natcap.invest import set_locale -from natcap.invest import spec_utils -from natcap.invest import ui_server -from natcap.invest import utils - +from pygeoprocessing.geoprocessing_core import GDALUseExceptions +with GDALUseExceptions(): + import natcap.invest + from natcap.invest import datastack + from natcap.invest import model_metadata + from natcap.invest import set_locale + from natcap.invest import spec_utils + from natcap.invest import ui_server + from natcap.invest import utils DEFAULT_EXIT_CODE = 1 LOGGER = logging.getLogger(__name__) @@ -218,267 +219,268 @@ def main(user_args=None): so models may be run in this way without having GUI packages installed. """ - parser = argparse.ArgumentParser( - description=( - 'Integrated Valuation of Ecosystem Services and Tradeoffs. ' - 'InVEST (Integrated Valuation of Ecosystem Services and ' - 'Tradeoffs) is a family of tools for quantifying the values of ' - 'natural capital in clear, credible, and practical ways. In ' - 'promising a return (of societal benefits) on investments in ' - 'nature, the scientific community needs to deliver knowledge and ' - 'tools to quantify and forecast this return. InVEST enables ' - 'decision-makers to quantify the importance of natural capital, ' - 'to assess the tradeoffs associated with alternative choices, ' - 'and to integrate conservation and human development. \n\n' - 'Older versions of InVEST ran as script tools in the ArcGIS ' - 'ArcToolBox environment, but have almost all been ported over to ' - 'a purely open-source python environment.'), - prog='invest' - ) - parser.add_argument('--version', action='version', - version=natcap.invest.__version__) - verbosity_group = parser.add_mutually_exclusive_group() - verbosity_group.add_argument( - '-v', '--verbose', dest='verbosity', default=0, action='count', - help=('Increase verbosity. Affects how much logging is printed to ' - 'the console and (if running in headless mode) how much is ' - 'written to the logfile.')) - verbosity_group.add_argument( - '--debug', dest='log_level', default=logging.ERROR, - action='store_const', const=logging.DEBUG, - help='Enable debug logging. Alias for -vvv') - - parser.add_argument( - '--taskgraph-log-level', dest='taskgraph_log_level', default='ERROR', - type=str, choices=['DEBUG', 'INFO', 'WARNING', 'ERROR'], - help=('Set the logging level for Taskgraph. Affects how much logging ' - 'Taskgraph prints to the console and (if running in headless ' - 'mode) how much is written to the logfile.')) - - # list the language code and corresponding language name (in that language) - supported_languages_string = ', '.join([ - f'{locale} ({display_name})' - for locale, display_name in natcap.invest.LOCALE_NAME_MAP.items()]) - parser.add_argument( - '-L', '--language', default='en', - choices=natcap.invest.LOCALES, - help=('Choose a language. Model specs, names, and validation messages ' - 'will be translated. Log messages are not translated. Value ' - 'should be an ISO 639-1 language code. Supported options are: ' - f'{supported_languages_string}.')) - - subparsers = parser.add_subparsers(dest='subcommand') - - listmodels_subparser = subparsers.add_parser( - 'list', help='List the available InVEST models') - listmodels_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - - run_subparser = subparsers.add_parser( - 'run', help='Run an InVEST model') - # Recognize '--headless' for backwards compatibility. - # This arg is otherwise unused. - run_subparser.add_argument( - '-l', '--headless', action='store_true', - help=argparse.SUPPRESS) - run_subparser.add_argument( - '-d', '--datastack', default=None, nargs='?', - help=('Run the specified model with this JSON datastack. ' - 'Required if using --headless')) - run_subparser.add_argument( - '-w', '--workspace', default=None, nargs='?', - help=('The workspace in which outputs will be saved. ' - 'Required if using --headless')) - run_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model to run. Use "invest list" to list the available ' - 'models.')) - - validate_subparser = subparsers.add_parser( - 'validate', help=( - 'Validate the parameters of a datastack')) - validate_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - validate_subparser.add_argument( - 'datastack', help=('Path to a JSON datastack.')) - - getspec_subparser = subparsers.add_parser( - 'getspec', help=('Get the specification of a model.')) - getspec_subparser.add_argument( - '--json', action='store_true', help='Write output as a JSON object') - getspec_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model for which the spec should be fetched. Use "invest ' - 'list" to list the available models.')) - - serve_subparser = subparsers.add_parser( - 'serve', help=('Start the flask app on the localhost.')) - serve_subparser.add_argument( - '--port', type=int, default=56789, - help='Port number for the Flask server') - - export_py_subparser = subparsers.add_parser( - 'export-py', help=('Save a python script that executes a model.')) - export_py_subparser.add_argument( - 'model', action=SelectModelAction, # Assert valid model name - help=('The model that the python script will execute. Use "invest ' - 'list" to list the available models.')) - export_py_subparser.add_argument( - '-f', '--filepath', default=None, - help='Define a location for the saved .py file') - - args = parser.parse_args(user_args) - natcap.invest.set_locale(args.language) - - root_logger = logging.getLogger() - handler = logging.StreamHandler(sys.stdout) - formatter = logging.Formatter( - fmt='%(asctime)s %(name)-18s %(levelname)-8s %(message)s', - datefmt='%m/%d/%Y %H:%M:%S ') - handler.setFormatter(formatter) - - # Set the log level based on what the user provides in the available - # arguments. Verbosity: the more v's the lower the logging threshold. - # If --debug is used, the logging threshold is 10. - # If the user goes lower than logging.DEBUG, default to logging.DEBUG. - log_level = min(args.log_level, logging.ERROR - (args.verbosity*10)) - handler.setLevel(max(log_level, logging.DEBUG)) # don't go below DEBUG - root_logger.addHandler(handler) - LOGGER.info('Setting handler log level to %s', log_level) - - # Set the log level for taskgraph. - taskgraph_log_level = logging.getLevelName(args.taskgraph_log_level.upper()) - logging.getLogger('taskgraph').setLevel(taskgraph_log_level) - LOGGER.debug('Setting taskgraph log level to %s', taskgraph_log_level) - - # FYI: Root logger by default has a level of logging.WARNING. - # To capture ALL logging produced in this system at runtime, use this: - # logging.getLogger().setLevel(logging.DEBUG) - # Also FYI: using logging.DEBUG means that the logger will defer to - # the setting of the parent logger. - logging.getLogger('natcap').setLevel(logging.DEBUG) - - if args.subcommand == 'list': - # reevaluate the model names in the new language - importlib.reload(model_metadata) - if args.json: - message = build_model_list_json() - else: - message = build_model_list_table() - - sys.stdout.write(message) - parser.exit() - - if args.subcommand == 'validate': - try: - parsed_datastack = datastack.extract_parameter_set(args.datastack) - except Exception as error: - parser.exit( - 1, "Error when parsing JSON datastack:\n " + str(error)) - - # reload validation module first so it's also in the correct language - importlib.reload(importlib.import_module('natcap.invest.validation')) - model_module = importlib.reload(importlib.import_module( - name=parsed_datastack.model_name)) - - try: - validation_result = model_module.validate(parsed_datastack.args) - except KeyError as missing_keys_error: + with GDALUseExceptions(): + parser = argparse.ArgumentParser( + description=( + 'Integrated Valuation of Ecosystem Services and Tradeoffs. ' + 'InVEST (Integrated Valuation of Ecosystem Services and ' + 'Tradeoffs) is a family of tools for quantifying the values of ' + 'natural capital in clear, credible, and practical ways. In ' + 'promising a return (of societal benefits) on investments in ' + 'nature, the scientific community needs to deliver knowledge and ' + 'tools to quantify and forecast this return. InVEST enables ' + 'decision-makers to quantify the importance of natural capital, ' + 'to assess the tradeoffs associated with alternative choices, ' + 'and to integrate conservation and human development. \n\n' + 'Older versions of InVEST ran as script tools in the ArcGIS ' + 'ArcToolBox environment, but have almost all been ported over to ' + 'a purely open-source python environment.'), + prog='invest' + ) + parser.add_argument('--version', action='version', + version=natcap.invest.__version__) + verbosity_group = parser.add_mutually_exclusive_group() + verbosity_group.add_argument( + '-v', '--verbose', dest='verbosity', default=0, action='count', + help=('Increase verbosity. Affects how much logging is printed to ' + 'the console and (if running in headless mode) how much is ' + 'written to the logfile.')) + verbosity_group.add_argument( + '--debug', dest='log_level', default=logging.ERROR, + action='store_const', const=logging.DEBUG, + help='Enable debug logging. Alias for -vvv') + + parser.add_argument( + '--taskgraph-log-level', dest='taskgraph_log_level', default='ERROR', + type=str, choices=['DEBUG', 'INFO', 'WARNING', 'ERROR'], + help=('Set the logging level for Taskgraph. Affects how much logging ' + 'Taskgraph prints to the console and (if running in headless ' + 'mode) how much is written to the logfile.')) + + # list the language code and corresponding language name (in that language) + supported_languages_string = ', '.join([ + f'{locale} ({display_name})' + for locale, display_name in natcap.invest.LOCALE_NAME_MAP.items()]) + parser.add_argument( + '-L', '--language', default='en', + choices=natcap.invest.LOCALES, + help=('Choose a language. Model specs, names, and validation messages ' + 'will be translated. Log messages are not translated. Value ' + 'should be an ISO 639-1 language code. Supported options are: ' + f'{supported_languages_string}.')) + + subparsers = parser.add_subparsers(dest='subcommand') + + listmodels_subparser = subparsers.add_parser( + 'list', help='List the available InVEST models') + listmodels_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + + run_subparser = subparsers.add_parser( + 'run', help='Run an InVEST model') + # Recognize '--headless' for backwards compatibility. + # This arg is otherwise unused. + run_subparser.add_argument( + '-l', '--headless', action='store_true', + help=argparse.SUPPRESS) + run_subparser.add_argument( + '-d', '--datastack', default=None, nargs='?', + help=('Run the specified model with this JSON datastack. ' + 'Required if using --headless')) + run_subparser.add_argument( + '-w', '--workspace', default=None, nargs='?', + help=('The workspace in which outputs will be saved. ' + 'Required if using --headless')) + run_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model to run. Use "invest list" to list the available ' + 'models.')) + + validate_subparser = subparsers.add_parser( + 'validate', help=( + 'Validate the parameters of a datastack')) + validate_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + validate_subparser.add_argument( + 'datastack', help=('Path to a JSON datastack.')) + + getspec_subparser = subparsers.add_parser( + 'getspec', help=('Get the specification of a model.')) + getspec_subparser.add_argument( + '--json', action='store_true', help='Write output as a JSON object') + getspec_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model for which the spec should be fetched. Use "invest ' + 'list" to list the available models.')) + + serve_subparser = subparsers.add_parser( + 'serve', help=('Start the flask app on the localhost.')) + serve_subparser.add_argument( + '--port', type=int, default=56789, + help='Port number for the Flask server') + + export_py_subparser = subparsers.add_parser( + 'export-py', help=('Save a python script that executes a model.')) + export_py_subparser.add_argument( + 'model', action=SelectModelAction, # Assert valid model name + help=('The model that the python script will execute. Use "invest ' + 'list" to list the available models.')) + export_py_subparser.add_argument( + '-f', '--filepath', default=None, + help='Define a location for the saved .py file') + + args = parser.parse_args(user_args) + natcap.invest.set_locale(args.language) + + root_logger = logging.getLogger() + handler = logging.StreamHandler(sys.stdout) + formatter = logging.Formatter( + fmt='%(asctime)s %(name)-18s %(levelname)-8s %(message)s', + datefmt='%m/%d/%Y %H:%M:%S ') + handler.setFormatter(formatter) + + # Set the log level based on what the user provides in the available + # arguments. Verbosity: the more v's the lower the logging threshold. + # If --debug is used, the logging threshold is 10. + # If the user goes lower than logging.DEBUG, default to logging.DEBUG. + log_level = min(args.log_level, logging.ERROR - (args.verbosity*10)) + handler.setLevel(max(log_level, logging.DEBUG)) # don't go below DEBUG + root_logger.addHandler(handler) + LOGGER.info('Setting handler log level to %s', log_level) + + # Set the log level for taskgraph. + taskgraph_log_level = logging.getLevelName(args.taskgraph_log_level.upper()) + logging.getLogger('taskgraph').setLevel(taskgraph_log_level) + LOGGER.debug('Setting taskgraph log level to %s', taskgraph_log_level) + + # FYI: Root logger by default has a level of logging.WARNING. + # To capture ALL logging produced in this system at runtime, use this: + # logging.getLogger().setLevel(logging.DEBUG) + # Also FYI: using logging.DEBUG means that the logger will defer to + # the setting of the parent logger. + logging.getLogger('natcap').setLevel(logging.DEBUG) + + if args.subcommand == 'list': + # reevaluate the model names in the new language + importlib.reload(model_metadata) if args.json: - message = json.dumps( - {'validation_results': { - str(list(missing_keys_error.args)): 'Key is missing'}}) + message = build_model_list_json() else: - message = ('Datastack is missing keys:\n ' + - str(missing_keys_error.args)) + message = build_model_list_table() - # Missing keys have an exit code of 1 because that would indicate - # probably programmer error. sys.stdout.write(message) - parser.exit(1) - except Exception as error: - parser.exit( - 1, ('Datastack could not be validated:\n ' + - str(error))) + parser.exit() - # Even validation errors will have an exit code of 0 - if args.json: - message = json.dumps({ - 'validation_results': validation_result}) - else: - message = pprint.pformat(validation_result) + if args.subcommand == 'validate': + try: + parsed_datastack = datastack.extract_parameter_set(args.datastack) + except Exception as error: + parser.exit( + 1, "Error when parsing JSON datastack:\n " + str(error)) + + # reload validation module first so it's also in the correct language + importlib.reload(importlib.import_module('natcap.invest.validation')) + model_module = importlib.reload(importlib.import_module( + name=parsed_datastack.model_name)) + + try: + validation_result = model_module.validate(parsed_datastack.args) + except KeyError as missing_keys_error: + if args.json: + message = json.dumps( + {'validation_results': { + str(list(missing_keys_error.args)): 'Key is missing'}}) + else: + message = ('Datastack is missing keys:\n ' + + str(missing_keys_error.args)) + + # Missing keys have an exit code of 1 because that would indicate + # probably programmer error. + sys.stdout.write(message) + parser.exit(1) + except Exception as error: + parser.exit( + 1, ('Datastack could not be validated:\n ' + + str(error))) - sys.stdout.write(message) - parser.exit(0) + # Even validation errors will have an exit code of 0 + if args.json: + message = json.dumps({ + 'validation_results': validation_result}) + else: + message = pprint.pformat(validation_result) - if args.subcommand == 'getspec': - target_model = model_metadata.MODEL_METADATA[args.model].pyname - model_module = importlib.reload( - importlib.import_module(name=target_model)) - spec = model_module.MODEL_SPEC + sys.stdout.write(message) + parser.exit(0) - if args.json: - message = spec_utils.serialize_args_spec(spec) - else: - message = pprint.pformat(spec) - sys.stdout.write(message) - parser.exit(0) - - if args.subcommand == 'run': - if args.headless: - warnings.warn( - '--headless (-l) is now the default (and only) behavior ' - 'for `invest run`. This flag will not be recognized ' - 'in the future.', FutureWarning, stacklevel=2) # 2 for brevity - if not args.datastack: - parser.exit(1, 'Datastack required for execution.') - - try: - parsed_datastack = datastack.extract_parameter_set(args.datastack) - except Exception as error: - parser.exit( - 1, "Error when parsing JSON datastack:\n " + str(error)) + if args.subcommand == 'getspec': + target_model = model_metadata.MODEL_METADATA[args.model].pyname + model_module = importlib.reload( + importlib.import_module(name=target_model)) + spec = model_module.MODEL_SPEC - if not args.workspace: - if ('workspace_dir' not in parsed_datastack.args or - parsed_datastack.args['workspace_dir'] in ['', None]): + if args.json: + message = spec_utils.serialize_args_spec(spec) + else: + message = pprint.pformat(spec) + sys.stdout.write(message) + parser.exit(0) + + if args.subcommand == 'run': + if args.headless: + warnings.warn( + '--headless (-l) is now the default (and only) behavior ' + 'for `invest run`. This flag will not be recognized ' + 'in the future.', FutureWarning, stacklevel=2) # 2 for brevity + if not args.datastack: + parser.exit(1, 'Datastack required for execution.') + + try: + parsed_datastack = datastack.extract_parameter_set(args.datastack) + except Exception as error: parser.exit( - 1, ('Workspace must be defined at the command line ' - 'or in the datastack file')) - else: - parsed_datastack.args['workspace_dir'] = args.workspace - - target_model = model_metadata.MODEL_METADATA[args.model].pyname - model_module = importlib.import_module(name=target_model) - LOGGER.info('Imported target %s from %s', - model_module.__name__, model_module) - - with utils.prepare_workspace(parsed_datastack.args['workspace_dir'], - name=parsed_datastack.model_name, - logging_level=log_level): - LOGGER.log(datastack.ARGS_LOG_LEVEL, - 'Starting model with parameters: \n%s', - datastack.format_args_dict(parsed_datastack.args, - parsed_datastack.model_name)) - - # We're deliberately not validating here because the user - # can just call ``invest validate `` to validate. - # - # Exceptions will already be logged to the logfile but will ALSO be - # written to stdout if this exception is uncaught. This is by - # design. - model_module.execute(parsed_datastack.args) - - if args.subcommand == 'serve': - ui_server.app.run(port=args.port) - parser.exit(0) - - if args.subcommand == 'export-py': - target_filepath = args.filepath - if not args.filepath: - target_filepath = f'{args.model}_execute.py' - export_to_python(target_filepath, args.model) - parser.exit() + 1, "Error when parsing JSON datastack:\n " + str(error)) + + if not args.workspace: + if ('workspace_dir' not in parsed_datastack.args or + parsed_datastack.args['workspace_dir'] in ['', None]): + parser.exit( + 1, ('Workspace must be defined at the command line ' + 'or in the datastack file')) + else: + parsed_datastack.args['workspace_dir'] = args.workspace + + target_model = model_metadata.MODEL_METADATA[args.model].pyname + model_module = importlib.import_module(name=target_model) + LOGGER.info('Imported target %s from %s', + model_module.__name__, model_module) + + with utils.prepare_workspace(parsed_datastack.args['workspace_dir'], + name=parsed_datastack.model_name, + logging_level=log_level): + LOGGER.log(datastack.ARGS_LOG_LEVEL, + 'Starting model with parameters: \n%s', + datastack.format_args_dict(parsed_datastack.args, + parsed_datastack.model_name)) + + # We're deliberately not validating here because the user + # can just call ``invest validate `` to validate. + # + # Exceptions will already be logged to the logfile but will ALSO be + # written to stdout if this exception is uncaught. This is by + # design. + model_module.execute(parsed_datastack.args) + + if args.subcommand == 'serve': + ui_server.app.run(port=args.port) + parser.exit(0) + + if args.subcommand == 'export-py': + target_filepath = args.filepath + if not args.filepath: + target_filepath = f'{args.model}_execute.py' + export_to_python(target_filepath, args.model) + parser.exit() if __name__ == '__main__': From f8712859f9a99fdd4ea7e384bf5b5e23e012e8fb Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Tue, 19 Nov 2024 14:20:25 -0800 Subject: [PATCH 67/90] add history note --- HISTORY.rst | 2 ++ 1 file changed, 2 insertions(+) diff --git a/HISTORY.rst b/HISTORY.rst index 3727f646e4..0e46d6e70a 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -48,6 +48,8 @@ Unreleased Changes reflect changes in how InVEST is installed on modern systems, and also to include images of the InVEST workbench instead of just broken links. https://github.com/natcap/invest/issues/1660 + * natcap.invest now works with (and requires) ``gdal.UseExceptions``. A + ``FutureWarning`` is raised on import if GDAL exceptions are not enabled. * Workbench * Several small updates to the model input form UI to improve usability and visual consistency (https://github.com/natcap/invest/issues/912). From 99c00be97ab9873e220253d482fc1d0ec7eb54b9 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Thu, 21 Nov 2024 10:49:59 -0800 Subject: [PATCH 68/90] update to UG revision with new translations; add history note --- HISTORY.rst | 2 ++ Makefile | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/HISTORY.rst b/HISTORY.rst index dfa49b3025..583b8f16c6 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -48,6 +48,8 @@ Unreleased Changes * Fixed a bug that, in certain scenarios, caused a datastack to be saved with relative paths when the Relative Paths checkbox was left unchecked (https://github.com/natcap/invest/issues/1609) +* General + * Updated translations for Spanish and Chinese 3.14.2 (2024-05-29) ------------------- diff --git a/Makefile b/Makefile index 234e814bbf..7520b25831 100644 --- a/Makefile +++ b/Makefile @@ -10,7 +10,7 @@ GIT_TEST_DATA_REPO_REV := 324abde73e1d770ad75921466ecafd1ec6297752 GIT_UG_REPO := https://github.com/natcap/invest.users-guide GIT_UG_REPO_PATH := doc/users-guide -GIT_UG_REPO_REV := 0404bc5d4d43085cdc58f50f8fc29944b10cefb1 +GIT_UG_REPO_REV := 5ee3616d4549baf3b1e44e0fcef485145389e29a ENV = "./env" ifeq ($(OS),Windows_NT) From f80212f78cf0b6ed4c4b9dd23000a6d923c3810b Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Thu, 21 Nov 2024 13:10:01 -0800 Subject: [PATCH 69/90] add pyyaml requirement to docs requirements for ug --- requirements-docs.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/requirements-docs.txt b/requirements-docs.txt index b3a24b5ec0..43ca362705 100644 --- a/requirements-docs.txt +++ b/requirements-docs.txt @@ -2,3 +2,4 @@ Sphinx>=1.3.1,!=1.7.1 sphinx-rtd-theme sphinx-intl sphinx-reredirects +pyyaml From 71c245fbcf411823098791fa791eed09379205d3 Mon Sep 17 00:00:00 2001 From: Emily Soth Date: Thu, 21 Nov 2024 16:06:53 -0800 Subject: [PATCH 70/90] correct numbering of steps in workbench readme --- workbench/readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/workbench/readme.md b/workbench/readme.md index c5e3893d63..bdd6c40f5d 100644 --- a/workbench/readme.md +++ b/workbench/readme.md @@ -137,7 +137,7 @@ These instructions assume you have defined the two-letter locale code in an envi ``` -7. Commit the changes: +6. Commit the changes: ``` git add src/main/i18n/$LL.json src/renderer/i18n/$LL.json git commit -m "add new translations for $LL" From a56b12157624f0f01882c63164244db126dfdfdb Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Fri, 22 Nov 2024 14:47:35 -0700 Subject: [PATCH 71/90] Encapsulated logic for generating monthly et and precip path lists into new function _get_monthly_file_lists and altered regex to accept zero-padded month numbers --- .../seasonal_water_yield.py | 62 +++++++++++++------ 1 file changed, 42 insertions(+), 20 deletions(-) diff --git a/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py b/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py index 728859a2d7..90521d2684 100644 --- a/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py +++ b/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py @@ -659,9 +659,6 @@ def execute(args): output_align_list = [ file_registry['lulc_aligned_path'], file_registry['dem_aligned_path']] if not args['user_defined_local_recharge']: - precip_path_list = [] - et0_path_list = [] - et0_dir_list = [ os.path.join(args['et0_dir'], f) for f in os.listdir( args['et0_dir'])] @@ -669,23 +666,8 @@ def execute(args): os.path.join(args['precip_dir'], f) for f in os.listdir( args['precip_dir'])] - for month_index in range(1, N_MONTHS + 1): - month_file_match = re.compile(r'.*[^\d]%d\.[^.]+$' % month_index) - - for data_type, dir_list, path_list in [ - ('et0', et0_dir_list, et0_path_list), - ('Precip', precip_dir_list, precip_path_list)]: - file_list = [ - month_file_path for month_file_path in dir_list - if month_file_match.match(month_file_path)] - if len(file_list) == 0: - raise ValueError( - "No %s found for month %d" % (data_type, month_index)) - if len(file_list) > 1: - raise ValueError( - "Ambiguous set of files found for month %d: %s" % - (month_index, file_list)) - path_list.append(file_list[0]) + et0_path_list, precip_path_list = _get_monthly_file_lists( + N_MONTHS, et0_dir_list, precip_dir_list) input_align_list = ( precip_path_list + [args['soil_group_path']] + et0_path_list + @@ -1380,6 +1362,46 @@ def _aggregate_recharge( aggregate_vector = None +def _get_monthly_file_lists(n_months, et0_dir_list, precip_dir_list): + """Create lists of monthly files for precipitation and evapotranspiration. + + Parameters: + n_months (int): The number of months to iterate over (should be 12) + et0_dir_list (list): List of file paths in evapotranspiration directory + precip_dir_list (list): List of file paths in precipitation directory + + Raises: + ValueError: If no file or multiple files are found for a month for + precipitation or et data. + + Returns: + tuple: Two lists containing the monthly file paths + for evapotranspiration and precipitation, respectively. + """ + et0_path_list = [] + precip_path_list = [] + + for month_index in range(1, n_months + 1): + month_file_pattern = re.compile(r'.*[^\d]0?%d\.[^.]+$' % month_index) + + for data_type, dir_list, path_list in [ + ('et0', et0_dir_list, et0_path_list), + ('Precip', precip_dir_list, precip_path_list)]: + file_list = [ + month_file_path for month_file_path in dir_list + if month_file_pattern.match(month_file_path)] + if len(file_list) == 0: + raise ValueError( + "No %s found for month %d" % (data_type, month_index)) + if len(file_list) > 1: + raise ValueError( + "Ambiguous set of files found for month %d: %s" % + (month_index, file_list)) + path_list.append(file_list[0]) + + return et0_path_list, precip_path_list + + @validation.invest_validator def validate(args, limit_to=None): """Validate args to ensure they conform to `execute`'s contract. From fcd2b2bdef2db3b01a39546ee989f905d1ad8da8 Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Fri, 22 Nov 2024 16:20:19 -0700 Subject: [PATCH 72/90] added unit test for input et and precip filenames with zero-padded months --- tests/test_seasonal_water_yield_regression.py | 20 +++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/tests/test_seasonal_water_yield_regression.py b/tests/test_seasonal_water_yield_regression.py index e795d85999..0eafe7be29 100644 --- a/tests/test_seasonal_water_yield_regression.py +++ b/tests/test_seasonal_water_yield_regression.py @@ -318,6 +318,26 @@ def tearDown(self): """Delete workspace after test is done.""" shutil.rmtree(self.workspace_dir, ignore_errors=True) + def test_zeropadded_monthly_filenames(self): + """test filenames with zero-padded months in + _get_monthly_file_lists function + """ + from natcap.invest.seasonal_water_yield import _get_monthly_file_lists + n_months = 12 + + # Make fake paths with file names with zero-padded months + padded_et0_dir_list = [os.path.join("/fake/path", + "et0_" + str(mo).zfill(2) + ".tif") for mo in range(1, n_months+1)] + padded_precip_dir_list = [os.path.join("/fake/path", + "Precip" + str(mo).zfill(2) + ".tif") for mo in range(1, n_months+1)] + + et0_path_list, precip_path_list = _get_monthly_file_lists( + n_months, padded_et0_dir_list, padded_precip_dir_list) + + # Verify that the returned lists match the input + self.assertEqual(et0_path_list, padded_et0_dir_list) + self.assertEqual(precip_path_list, padded_precip_dir_list) + def test_ambiguous_precip_data(self): """SWY test case where there are more than 12 precipitation files.""" from natcap.invest.seasonal_water_yield import seasonal_water_yield From de7ea8caa08db0bbbe72a0b22dd428907197f710 Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Mon, 25 Nov 2024 11:59:37 -0700 Subject: [PATCH 73/90] fixed import statement in test_zeropadded_monthly_filenames --- tests/test_seasonal_water_yield_regression.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/test_seasonal_water_yield_regression.py b/tests/test_seasonal_water_yield_regression.py index 0eafe7be29..3142b345a2 100644 --- a/tests/test_seasonal_water_yield_regression.py +++ b/tests/test_seasonal_water_yield_regression.py @@ -322,7 +322,7 @@ def test_zeropadded_monthly_filenames(self): """test filenames with zero-padded months in _get_monthly_file_lists function """ - from natcap.invest.seasonal_water_yield import _get_monthly_file_lists + from natcap.invest.seasonal_water_yield.seasonal_water_yield import _get_monthly_file_lists n_months = 12 # Make fake paths with file names with zero-padded months From c51422a3750cccae98e149830e700403ed69524a Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Mon, 25 Nov 2024 13:42:50 -0700 Subject: [PATCH 74/90] updated history for SWY to note new ability to zero pad months --- HISTORY.rst | 3 +++ 1 file changed, 3 insertions(+) diff --git a/HISTORY.rst b/HISTORY.rst index 09455fe2e0..1bb27b9161 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -86,6 +86,9 @@ Unreleased Changes updated the stated dtype of most pollination model outputs to be float32 instead of the float64 dtype that was being assumed previously. This will result in smaller output filesizes with minimal loss of precision. +* Seasonal Water Yield + * Added support for zero padding in month numbers in ET and precipitation + file names (i.e., users can now name their file Precip_01.tif). * Urban Flood Risk * Fields present on the input AOI vector are now retained in the output. (https://github.com/natcap/invest/issues/1600) From 46e7204ab8c46d32ced4a4cf537e3774f97cb84a Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Mon, 25 Nov 2024 15:13:39 -0700 Subject: [PATCH 75/90] fixed lint error --- HISTORY.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/HISTORY.rst b/HISTORY.rst index 1bb27b9161..c980001641 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -87,7 +87,7 @@ Unreleased Changes instead of the float64 dtype that was being assumed previously. This will result in smaller output filesizes with minimal loss of precision. * Seasonal Water Yield - * Added support for zero padding in month numbers in ET and precipitation + * Added support for zero padding in month numbers in ET and precipitation file names (i.e., users can now name their file Precip_01.tif). * Urban Flood Risk * Fields present on the input AOI vector are now retained in the output. From ff25b892f2f797bc28e5d8320ed3cde3b9f5d7e1 Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Mon, 25 Nov 2024 15:29:11 -0700 Subject: [PATCH 76/90] fixed line len lint error --- tests/test_seasonal_water_yield_regression.py | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/tests/test_seasonal_water_yield_regression.py b/tests/test_seasonal_water_yield_regression.py index 3142b345a2..791abb5ec5 100644 --- a/tests/test_seasonal_water_yield_regression.py +++ b/tests/test_seasonal_water_yield_regression.py @@ -319,17 +319,21 @@ def tearDown(self): shutil.rmtree(self.workspace_dir, ignore_errors=True) def test_zeropadded_monthly_filenames(self): - """test filenames with zero-padded months in + """test filenames with zero-padded months in _get_monthly_file_lists function """ - from natcap.invest.seasonal_water_yield.seasonal_water_yield import _get_monthly_file_lists + from natcap.invest.seasonal_water_yield.seasonal_water_yield import ( + _get_monthly_file_lists) + n_months = 12 - + # Make fake paths with file names with zero-padded months - padded_et0_dir_list = [os.path.join("/fake/path", - "et0_" + str(mo).zfill(2) + ".tif") for mo in range(1, n_months+1)] - padded_precip_dir_list = [os.path.join("/fake/path", - "Precip" + str(mo).zfill(2) + ".tif") for mo in range(1, n_months+1)] + padded_et0_dir_list = [ + os.path.join("/fake/path", "et0_" + str(mo).zfill(2) + ".tif") + for mo in range(1, n_months+1)] + padded_precip_dir_list = [ + os.path.join("/fake/path", "Precip" + str(mo).zfill(2) + ".tif") + for mo in range(1, n_months + 1)] et0_path_list, precip_path_list = _get_monthly_file_lists( n_months, padded_et0_dir_list, padded_precip_dir_list) From 7be8b9cf1742d9f51253303dd0867044e5ba0e3a Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Mon, 25 Nov 2024 15:36:47 -0700 Subject: [PATCH 77/90] added issue# to history --- HISTORY.rst | 1 + 1 file changed, 1 insertion(+) diff --git a/HISTORY.rst b/HISTORY.rst index c980001641..c0b54a365c 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -89,6 +89,7 @@ Unreleased Changes * Seasonal Water Yield * Added support for zero padding in month numbers in ET and precipitation file names (i.e., users can now name their file Precip_01.tif). + (https://github.com/natcap/invest/issues/1166) * Urban Flood Risk * Fields present on the input AOI vector are now retained in the output. (https://github.com/natcap/invest/issues/1600) From 0d42b9a6dd5b39ae51bea4be5c3146bfb93135e8 Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Tue, 26 Nov 2024 15:38:41 -0700 Subject: [PATCH 78/90] Updated _get_monthly_file_lists to operate on one directory and read file lists within function --- .../seasonal_water_yield.py | 63 ++++++++----------- 1 file changed, 26 insertions(+), 37 deletions(-) diff --git a/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py b/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py index 90521d2684..b71ce93d1c 100644 --- a/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py +++ b/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py @@ -659,15 +659,8 @@ def execute(args): output_align_list = [ file_registry['lulc_aligned_path'], file_registry['dem_aligned_path']] if not args['user_defined_local_recharge']: - et0_dir_list = [ - os.path.join(args['et0_dir'], f) for f in os.listdir( - args['et0_dir'])] - precip_dir_list = [ - os.path.join(args['precip_dir'], f) for f in os.listdir( - args['precip_dir'])] - - et0_path_list, precip_path_list = _get_monthly_file_lists( - N_MONTHS, et0_dir_list, precip_dir_list) + precip_path_list = _get_monthly_file_lists(N_MONTHS, args['precip_dir']) + et0_path_list = _get_monthly_file_lists(N_MONTHS, args['et0_dir']) input_align_list = ( precip_path_list + [args['soil_group_path']] + et0_path_list + @@ -1362,44 +1355,40 @@ def _aggregate_recharge( aggregate_vector = None -def _get_monthly_file_lists(n_months, et0_dir_list, precip_dir_list): - """Create lists of monthly files for precipitation and evapotranspiration. +def _get_monthly_file_lists(n_months, in_dir): + """Create list of monthly files for data_type Parameters: - n_months (int): The number of months to iterate over (should be 12) - et0_dir_list (list): List of file paths in evapotranspiration directory - precip_dir_list (list): List of file paths in precipitation directory + n_months (int): Number of months to iterate over (should be 12) + in_dir (string): Path to directory of monthly files (for specific + variable) Raises: - ValueError: If no file or multiple files are found for a month for - precipitation or et data. + ValueError: If no file or multiple files are found for a month Returns: - tuple: Two lists containing the monthly file paths - for evapotranspiration and precipitation, respectively. + list: contains monthly file paths for specific variable """ - et0_path_list = [] - precip_path_list = [] - + in_path_list = [os.path.join(in_dir, f) for f in os.listdir(in_dir)] + out_path_list = [] + for month_index in range(1, n_months + 1): month_file_pattern = re.compile(r'.*[^\d]0?%d\.[^.]+$' % month_index) + file_list = [ + month_file_path for month_file_path in in_path_list + if month_file_pattern.match(month_file_path)] + if len(file_list) == 0: + raise ValueError( + "No files found in %s for month %d. Please ensure that \ + filenames end in the month number (e.g., precip_1.tif)." + % (in_dir, month_index)) + if len(file_list) > 1: + raise ValueError( + "Ambiguous set of files found for month %d: %s" % + (month_index, file_list)) + out_path_list.append(file_list[0]) - for data_type, dir_list, path_list in [ - ('et0', et0_dir_list, et0_path_list), - ('Precip', precip_dir_list, precip_path_list)]: - file_list = [ - month_file_path for month_file_path in dir_list - if month_file_pattern.match(month_file_path)] - if len(file_list) == 0: - raise ValueError( - "No %s found for month %d" % (data_type, month_index)) - if len(file_list) > 1: - raise ValueError( - "Ambiguous set of files found for month %d: %s" % - (month_index, file_list)) - path_list.append(file_list[0]) - - return et0_path_list, precip_path_list + return out_path_list @validation.invest_validator From 5435adf76db23bc45b5e5b05ba5d119650ff6cdf Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Tue, 26 Nov 2024 15:39:39 -0700 Subject: [PATCH 79/90] Updated test for zero-padded monthly files to work with updated _get_monthly_file_lists; added test for non-zero padded precip files --- tests/test_seasonal_water_yield_regression.py | 79 ++++++++++++++++--- 1 file changed, 66 insertions(+), 13 deletions(-) diff --git a/tests/test_seasonal_water_yield_regression.py b/tests/test_seasonal_water_yield_regression.py index 791abb5ec5..ba803d2f64 100644 --- a/tests/test_seasonal_water_yield_regression.py +++ b/tests/test_seasonal_water_yield_regression.py @@ -154,6 +154,7 @@ def make_precip_rasters(precip_dir_path): Args: precip_dir_path (str): path to the directory for saving the rasters. + file_prefix (str): prefix of new files to create. Returns: None. @@ -322,25 +323,77 @@ def test_zeropadded_monthly_filenames(self): """test filenames with zero-padded months in _get_monthly_file_lists function """ - from natcap.invest.seasonal_water_yield.seasonal_water_yield import ( - _get_monthly_file_lists) + from natcap.invest.seasonal_water_yield.seasonal_water_yield import _get_monthly_file_lists n_months = 12 - # Make fake paths with file names with zero-padded months - padded_et0_dir_list = [ - os.path.join("/fake/path", "et0_" + str(mo).zfill(2) + ".tif") - for mo in range(1, n_months+1)] - padded_precip_dir_list = [ - os.path.join("/fake/path", "Precip" + str(mo).zfill(2) + ".tif") - for mo in range(1, n_months + 1)] + # Make directory and file names with zero-padded months + precip_dir_path = os.path.join(self.workspace_dir, 'precip_dir') + test_precip_dir_path = os.path.join(self.workspace_dir, + 'test_0pad_precip_dir') + os.makedirs(precip_dir_path) + os.makedirs(test_precip_dir_path) + make_precip_rasters(precip_dir_path) + precip_file_list = [os.path.join(precip_dir_path, f) + for f in os.listdir(precip_dir_path)] + for raster, month in zip(precip_file_list, range(1, n_months+1)): + shutil.copy(raster, os.path.join( + test_precip_dir_path, "precip"+str(month).zfill(2)+".tif")) + + eto_dir_path = os.path.join(self.workspace_dir, "eto_dir") + test_eto_dir_path = os.path.join(self.workspace_dir, + 'test_0pad_eto_dir') + os.makedirs(eto_dir_path) + os.makedirs(test_eto_dir_path) + make_eto_rasters(eto_dir_path) + eto_file_list = [os.path.join(eto_dir_path, f) + for f in os.listdir(eto_dir_path)] + for raster, month in zip(eto_file_list, range(1, n_months+1)): + shutil.copy(raster, os.path.join( + test_eto_dir_path, "et0_"+str(month).zfill(2)+".tif")) + + # Create list of monthly files for data_type + eto_path_list = _get_monthly_file_lists( + n_months, test_eto_dir_path) + + precip_path_list = _get_monthly_file_lists( + n_months, test_precip_dir_path) + + # Create lists of monthly filenames to which to compare function output + match_precip = sorted([os.path.join(test_precip_dir_path, f) + for f in os.listdir(test_precip_dir_path)]) + match_eto = sorted([os.path.join(test_eto_dir_path, f) + for f in os.listdir(test_eto_dir_path)]) + + print(match_precip) + + # Verify that the returned lists match the input + self.assertEqual(precip_path_list, match_precip) + self.assertEqual(eto_path_list, match_eto) - et0_path_list, precip_path_list = _get_monthly_file_lists( - n_months, padded_et0_dir_list, padded_precip_dir_list) + def test_nonpadded_monthly_filenames(self): + """test filenames without zero-padded months in + _get_monthly_file_lists function + """ + from natcap.invest.seasonal_water_yield.seasonal_water_yield import _get_monthly_file_lists + + n_months = 12 + + # Make directory and file names with (non-zero-padded) months + precip_dir_path = os.path.join(self.workspace_dir, 'precip_dir') + os.makedirs(precip_dir_path) + make_precip_rasters(precip_dir_path) + precip_path_list = _get_monthly_file_lists( + n_months, precip_dir_path) + + # Create lists of monthly filenames to which to compare function output + match_precip = [os.path.join(precip_dir_path, + "precip_mm_" + str(m) + ".tif") + for m in range(1, n_months + 1)] + # Verify that the returned lists match the input - self.assertEqual(et0_path_list, padded_et0_dir_list) - self.assertEqual(precip_path_list, padded_precip_dir_list) + self.assertEqual(precip_path_list, match_precip) def test_ambiguous_precip_data(self): """SWY test case where there are more than 12 precipitation files.""" From 1774b53b87b9312bb71f3093a9fd9545e7a18613 Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Wed, 27 Nov 2024 11:41:19 -0700 Subject: [PATCH 80/90] Encapsulated creation of zero-padded monthly rasters into new function; clarified comments --- tests/test_seasonal_water_yield_regression.py | 56 ++++++++++--------- 1 file changed, 29 insertions(+), 27 deletions(-) diff --git a/tests/test_seasonal_water_yield_regression.py b/tests/test_seasonal_water_yield_regression.py index ba803d2f64..2b4359cbae 100644 --- a/tests/test_seasonal_water_yield_regression.py +++ b/tests/test_seasonal_water_yield_regression.py @@ -154,7 +154,6 @@ def make_precip_rasters(precip_dir_path): Args: precip_dir_path (str): path to the directory for saving the rasters. - file_prefix (str): prefix of new files to create. Returns: None. @@ -167,6 +166,30 @@ def make_precip_rasters(precip_dir_path): make_raster_from_array(precip_array, precip_raster_path) +def make_zeropadded_rasters(dir_path, prefix): + """Make twelve 1x1 raster files with filenames ending in zero-padded + month number. + + Args: + dir_path (str): path to the directory for saving the rasters. + file_prefix (str): prefix of new files to create. + + Returns: + list: monthly raster filenames + """ + size = 1 + monthly_raster_list = [] + + for month in range(1, 13): + raster_path = os.path.join( + dir_path, prefix + str(month).zfill(2) + '.tif') + temp_array = numpy.full((size, size), 1, dtype=numpy.int8) + make_raster_from_array(temp_array, raster_path) + monthly_raster_list.append(raster_path) + + return monthly_raster_list + + def make_recharge_raster(recharge_ras_path): """Make a 100x100 raster of user defined recharge. @@ -328,29 +351,15 @@ def test_zeropadded_monthly_filenames(self): n_months = 12 # Make directory and file names with zero-padded months - precip_dir_path = os.path.join(self.workspace_dir, 'precip_dir') test_precip_dir_path = os.path.join(self.workspace_dir, 'test_0pad_precip_dir') - os.makedirs(precip_dir_path) os.makedirs(test_precip_dir_path) - make_precip_rasters(precip_dir_path) - precip_file_list = [os.path.join(precip_dir_path, f) - for f in os.listdir(precip_dir_path)] - for raster, month in zip(precip_file_list, range(1, n_months+1)): - shutil.copy(raster, os.path.join( - test_precip_dir_path, "precip"+str(month).zfill(2)+".tif")) + precip_file_list = make_zeropadded_rasters(test_precip_dir_path, 'Prcp') - eto_dir_path = os.path.join(self.workspace_dir, "eto_dir") test_eto_dir_path = os.path.join(self.workspace_dir, 'test_0pad_eto_dir') - os.makedirs(eto_dir_path) os.makedirs(test_eto_dir_path) - make_eto_rasters(eto_dir_path) - eto_file_list = [os.path.join(eto_dir_path, f) - for f in os.listdir(eto_dir_path)] - for raster, month in zip(eto_file_list, range(1, n_months+1)): - shutil.copy(raster, os.path.join( - test_eto_dir_path, "et0_"+str(month).zfill(2)+".tif")) + eto_file_list = make_zeropadded_rasters(test_eto_dir_path, 'et0_') # Create list of monthly files for data_type eto_path_list = _get_monthly_file_lists( @@ -359,17 +368,9 @@ def test_zeropadded_monthly_filenames(self): precip_path_list = _get_monthly_file_lists( n_months, test_precip_dir_path) - # Create lists of monthly filenames to which to compare function output - match_precip = sorted([os.path.join(test_precip_dir_path, f) - for f in os.listdir(test_precip_dir_path)]) - match_eto = sorted([os.path.join(test_eto_dir_path, f) - for f in os.listdir(test_eto_dir_path)]) - - print(match_precip) - # Verify that the returned lists match the input - self.assertEqual(precip_path_list, match_precip) - self.assertEqual(eto_path_list, match_eto) + self.assertEqual(precip_path_list, precip_file_list) + self.assertEqual(eto_path_list, eto_file_list) def test_nonpadded_monthly_filenames(self): """test filenames without zero-padded months in @@ -388,6 +389,7 @@ def test_nonpadded_monthly_filenames(self): n_months, precip_dir_path) # Create lists of monthly filenames to which to compare function output + # Note this is hardcoded to match the filenames created in make_precip_rasters match_precip = [os.path.join(precip_dir_path, "precip_mm_" + str(m) + ".tif") for m in range(1, n_months + 1)] From 6d53d577ed87d4a7359f43dec857352f488f5826 Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Wed, 27 Nov 2024 11:43:44 -0700 Subject: [PATCH 81/90] Expanded error message and comments --- .../invest/seasonal_water_yield/seasonal_water_yield.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py b/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py index b71ce93d1c..e5c2ba57e0 100644 --- a/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py +++ b/src/natcap/invest/seasonal_water_yield/seasonal_water_yield.py @@ -1356,18 +1356,18 @@ def _aggregate_recharge( def _get_monthly_file_lists(n_months, in_dir): - """Create list of monthly files for data_type + """Create list of monthly files for data type Parameters: n_months (int): Number of months to iterate over (should be 12) in_dir (string): Path to directory of monthly files (for specific - variable) + data type) Raises: ValueError: If no file or multiple files are found for a month Returns: - list: contains monthly file paths for specific variable + list: contains monthly file paths for data type """ in_path_list = [os.path.join(in_dir, f) for f in os.listdir(in_dir)] out_path_list = [] @@ -1380,7 +1380,7 @@ def _get_monthly_file_lists(n_months, in_dir): if len(file_list) == 0: raise ValueError( "No files found in %s for month %d. Please ensure that \ - filenames end in the month number (e.g., precip_1.tif)." + filenames end in the month number (e.g., precip_1.tif)." % (in_dir, month_index)) if len(file_list) > 1: raise ValueError( From 008f35287c1bcab698934b6234a451f45d5b3895 Mon Sep 17 00:00:00 2001 From: davemfish Date: Tue, 3 Dec 2024 15:05:15 -0500 Subject: [PATCH 82/90] modify the PATH to give precedence to the pyinstaller dll directory. #1643 --- exe/hooks/rthook.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/exe/hooks/rthook.py b/exe/hooks/rthook.py index ec0b3264a8..5f76abe380 100644 --- a/exe/hooks/rthook.py +++ b/exe/hooks/rthook.py @@ -16,3 +16,10 @@ # sys._MEIPASS is the path to where the pyinstaller entrypoint bundle # lives. See the pyinstaller docs for more details. os.environ['SPATIALINDEX_C_LIBRARY'] = sys._MEIPASS + +if platform.system() == 'Windows': + # sys._MEIPASS contains gdal DLLs. It does not otherwise end + # up on the PATH, which means that gdal can discover + # incompatible DLLs from some other place on the PATH, such + # as an anaconda gdal installation. + os.environ['PATH'] = f"{sys._MEIPASS};{os.environ['PATH']}" From dc0628cf6fea2befaf01c7729548caac214821f8 Mon Sep 17 00:00:00 2001 From: davemfish Date: Tue, 3 Dec 2024 15:06:04 -0500 Subject: [PATCH 83/90] remove part of the runtime hook we no longer need since we no longer have a QT UI. #1643 --- exe/hooks/rthook.py | 5 ----- 1 file changed, 5 deletions(-) diff --git a/exe/hooks/rthook.py b/exe/hooks/rthook.py index 5f76abe380..7743b76616 100644 --- a/exe/hooks/rthook.py +++ b/exe/hooks/rthook.py @@ -5,11 +5,6 @@ os.environ['PROJ_LIB'] = os.path.join(sys._MEIPASS, 'proj') if platform.system() == 'Darwin': - # This allows Qt 5.13+ to start on Big Sur. - # See https://bugreports.qt.io/browse/QTBUG-87014 - # and https://github.com/natcap/invest/issues/384 - os.environ['QT_MAC_WANTS_LAYER'] = '1' - # Rtree will look in this directory first for libspatialindex_c.dylib. # In response to issues with github mac binary builds: # https://github.com/natcap/invest/issues/594 From 1628966becf54489e3932ad376649d82070af32b Mon Sep 17 00:00:00 2001 From: davemfish Date: Tue, 3 Dec 2024 15:08:29 -0500 Subject: [PATCH 84/90] guard against the case where there is no PATH variable. #1643 --- exe/hooks/rthook.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/exe/hooks/rthook.py b/exe/hooks/rthook.py index 7743b76616..492344124b 100644 --- a/exe/hooks/rthook.py +++ b/exe/hooks/rthook.py @@ -17,4 +17,5 @@ # up on the PATH, which means that gdal can discover # incompatible DLLs from some other place on the PATH, such # as an anaconda gdal installation. - os.environ['PATH'] = f"{sys._MEIPASS};{os.environ['PATH']}" + if 'PATH' in os.environ: + os.environ['PATH'] = f"{sys._MEIPASS};{os.environ['PATH']}" From ecb8bf0dbd8348c5340d01f6b53e3b1d2502e36a Mon Sep 17 00:00:00 2001 From: davemfish Date: Tue, 3 Dec 2024 17:32:42 -0500 Subject: [PATCH 85/90] note for HISTORY. #1643 --- HISTORY.rst | 3 +++ 1 file changed, 3 insertions(+) diff --git a/HISTORY.rst b/HISTORY.rst index c0b54a365c..abdfee9f61 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -51,6 +51,9 @@ Unreleased Changes * Updated translations for Spanish and Chinese * natcap.invest now works with (and requires) ``gdal.UseExceptions``. A ``FutureWarning`` is raised on import if GDAL exceptions are not enabled. + * Fixed an issue on Windows where GDAL fails to find its DLLs due to + an interfering GDAL installation on the PATH, such as from anaconda. + https://github.com/natcap/invest/issues/1643 * Workbench * Several small updates to the model input form UI to improve usability and visual consistency (https://github.com/natcap/invest/issues/912). From 939dcda54b2c08e2671f0b190abb44e657f6fd81 Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Fri, 6 Dec 2024 15:09:56 -0700 Subject: [PATCH 86/90] ensure no None/NA keys in value_map in reclassify_raster --- src/natcap/invest/utils.py | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/src/natcap/invest/utils.py b/src/natcap/invest/utils.py index dff0825a13..e3c1fc0e5b 100644 --- a/src/natcap/invest/utils.py +++ b/src/natcap/invest/utils.py @@ -741,14 +741,24 @@ def reclassify_raster( None Raises: - ValueError if ``values_required`` is ``True`` and a pixel value from - ``raster_path_band`` is not a key in ``value_map``. + ValueError: + - if ``values_required`` is ``True`` and a pixel value from + ``raster_path_band`` is not a key in ``value_map``. + - if there is a missing or invalid key in ``value_map``, such + as `None`, `NA`, or other values representing missing data. """ # Error early if 'error_details' keys are invalid raster_name = error_details['raster_name'] column_name = error_details['column_name'] table_name = error_details['table_name'] + # check keys in value map to ensure none are NA or None + if any((key is pandas.NA or key is None) + for key in value_map.keys()): + error_message = (f"Missing or NA value in '{column_name}' column" + f" in {table_name} table.") + raise TypeError(error_message) + try: pygeoprocessing.reclassify_raster( raster_path_band, value_map, target_raster_path, target_datatype, From 90ac6ab7951896a0d324981b7b0efdf7e6631dad Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Fri, 6 Dec 2024 15:11:20 -0700 Subject: [PATCH 87/90] test missing LULC value in sensitivity csv --- tests/test_habitat_quality.py | 52 +++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) diff --git a/tests/test_habitat_quality.py b/tests/test_habitat_quality.py index 143d113668..b1432bbb03 100644 --- a/tests/test_habitat_quality.py +++ b/tests/test_habitat_quality.py @@ -2133,3 +2133,55 @@ def test_habitat_quality_validate_missing_fut_column(self): header='column', header_name='fut_path') )] self.assertEqual(validate_result, expected) + + def test_habitat_quality_missing_lulc_val_in_sens_table(self): + """Habitat Quality: test for empty value in LULC column of + sensitivity table. Expects TypeError""" + from natcap.invest import habitat_quality + + args = { + 'half_saturation_constant': '0.5', + 'workspace_dir': self.workspace_dir, + 'n_workers': -1, + } + + args['access_vector_path'] = os.path.join( + args['workspace_dir'], 'access_samp.shp') + make_access_shp(args['access_vector_path']) + + scenarios = ['_bas_', '_cur_', '_fut_'] + for lulc_val, scenario in enumerate(scenarios, start=1): + lulc_array = numpy.ones((100, 100), dtype=numpy.int8) + lulc_array[50:, :] = lulc_val + args['lulc' + scenario + 'path'] = os.path.join( + args['workspace_dir'], 'lc_samp' + scenario + 'b.tif') + make_raster_from_array( + lulc_array, args['lulc' + scenario + 'path']) + + args['sensitivity_table_path'] = os.path.join( + args['workspace_dir'], 'sensitivity_samp.csv') + with open(args['sensitivity_table_path'], 'w') as open_table: + open_table.write('LULC,NAME,HABITAT,threat_1,threat_2\n') + open_table.write('1,"lulc 1",1,1,1\n') + open_table.write(',"lulc 2",0.5,0.5,1\n') # missing LULC value + open_table.write('3,"lulc 3",0,0.3,1\n') + + make_threats_raster( + args['workspace_dir'], threat_values=[1, 1], + dtype=numpy.int8, gdal_type=gdal.GDT_Int32, nodata_val=None) + + args['threats_table_path'] = os.path.join( + args['workspace_dir'], 'threats_samp.csv') + + # create the threat CSV table + with open(args['threats_table_path'], 'w') as open_table: + open_table.write( + 'MAX_DIST,WEIGHT,THREAT,DECAY,BASE_PATH,CUR_PATH,FUT_PATH\n') + open_table.write( + '0.04,0.7,threat_1,linear,,threat_1_c.tif,threat_1_f.tif\n') + open_table.write( + '0.07,1.0,threat_2,exponential,,threat_2_c.tif,' + 'threat_2_f.tif\n') + + with self.assertRaises(TypeError): + habitat_quality.execute(args) From 322d4981ee3d395c9664425c9a4e90127f5b98cc Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Fri, 6 Dec 2024 16:59:36 -0700 Subject: [PATCH 88/90] fixed dict .keys --- src/natcap/invest/utils.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/natcap/invest/utils.py b/src/natcap/invest/utils.py index e3c1fc0e5b..e38c54f28f 100644 --- a/src/natcap/invest/utils.py +++ b/src/natcap/invest/utils.py @@ -754,7 +754,7 @@ def reclassify_raster( # check keys in value map to ensure none are NA or None if any((key is pandas.NA or key is None) - for key in value_map.keys()): + for key in value_map): error_message = (f"Missing or NA value in '{column_name}' column" f" in {table_name} table.") raise TypeError(error_message) From 613bd1f42fca2702677da4f564d9126f6c57c587 Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Mon, 9 Dec 2024 11:10:45 -0700 Subject: [PATCH 89/90] updated history, reclassify func docstring, removed unneeded hq test elements --- HISTORY.rst | 4 ++++ src/natcap/invest/utils.py | 6 +++--- tests/test_habitat_quality.py | 17 +++++------------ 3 files changed, 12 insertions(+), 15 deletions(-) diff --git a/HISTORY.rst b/HISTORY.rst index abdfee9f61..c304770323 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -54,6 +54,8 @@ Unreleased Changes * Fixed an issue on Windows where GDAL fails to find its DLLs due to an interfering GDAL installation on the PATH, such as from anaconda. https://github.com/natcap/invest/issues/1643 + * Improved error handling of NA values in raster reclassification to provide + a more descriptive message. * Workbench * Several small updates to the model input form UI to improve usability and visual consistency (https://github.com/natcap/invest/issues/912). @@ -81,6 +83,8 @@ Unreleased Changes (https://github.com/natcap/invest/issues/1615). * Rarity values are now output in CSV format (as well as in raster format) (https://github.com/natcap/invest/issues/721). + * Improved error handling when there is a missing LULC value in the + sensitivity table (https://github.com/natcap/invest/issues/1671). * Pollination * Fixed an issue with nodata handling that was causing some outputs to be filled either with the float32 value for positive infinity, or else with diff --git a/src/natcap/invest/utils.py b/src/natcap/invest/utils.py index e38c54f28f..98a14e411e 100644 --- a/src/natcap/invest/utils.py +++ b/src/natcap/invest/utils.py @@ -742,10 +742,10 @@ def reclassify_raster( Raises: ValueError: - - if ``values_required`` is ``True`` and a pixel value from + - if ``values_required`` is ``True`` and a pixel value from ``raster_path_band`` is not a key in ``value_map``. - - if there is a missing or invalid key in ``value_map``, such - as `None`, `NA`, or other values representing missing data. + TypeError: + - if there is a ``None`` or ``NA`` key in ``value_map``. """ # Error early if 'error_details' keys are invalid raster_name = error_details['raster_name'] diff --git a/tests/test_habitat_quality.py b/tests/test_habitat_quality.py index b1432bbb03..db5d6b5d59 100644 --- a/tests/test_habitat_quality.py +++ b/tests/test_habitat_quality.py @@ -2145,18 +2145,11 @@ def test_habitat_quality_missing_lulc_val_in_sens_table(self): 'n_workers': -1, } - args['access_vector_path'] = os.path.join( - args['workspace_dir'], 'access_samp.shp') - make_access_shp(args['access_vector_path']) - - scenarios = ['_bas_', '_cur_', '_fut_'] - for lulc_val, scenario in enumerate(scenarios, start=1): - lulc_array = numpy.ones((100, 100), dtype=numpy.int8) - lulc_array[50:, :] = lulc_val - args['lulc' + scenario + 'path'] = os.path.join( - args['workspace_dir'], 'lc_samp' + scenario + 'b.tif') - make_raster_from_array( - lulc_array, args['lulc' + scenario + 'path']) + lulc_array = numpy.ones((100, 100), dtype=numpy.int8) + args['lulc_cur_path'] = os.path.join( + args['workspace_dir'], 'lc_samp_cur_b.tif') + make_raster_from_array( + lulc_array, args['lulc_cur_path']) args['sensitivity_table_path'] = os.path.join( args['workspace_dir'], 'sensitivity_samp.csv') From 36267de37016bbfca3446da6db117669e400459d Mon Sep 17 00:00:00 2001 From: Claire Simpson Date: Mon, 9 Dec 2024 12:08:21 -0700 Subject: [PATCH 90/90] lint error --- HISTORY.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/HISTORY.rst b/HISTORY.rst index c304770323..e1ae72528c 100644 --- a/HISTORY.rst +++ b/HISTORY.rst @@ -83,7 +83,7 @@ Unreleased Changes (https://github.com/natcap/invest/issues/1615). * Rarity values are now output in CSV format (as well as in raster format) (https://github.com/natcap/invest/issues/721). - * Improved error handling when there is a missing LULC value in the + * Improved error handling when there is a missing LULC value in the sensitivity table (https://github.com/natcap/invest/issues/1671). * Pollination * Fixed an issue with nodata handling that was causing some outputs to be