1) Неправильные выходные данные для режима степени:
asin(0.55) должен возвращать примерно 33,367 > градусов, но в настоящее время он возвращает 0,550.
acos(0,55) должен возвращать примерно 56,632 градусов, но в настоящее время он возвращает 89,449.
atan(0,55) должен возвращать примерно 28,810 градусов, но в настоящее время он возвращает 0,502.
2) Пределы проверки не применяются правильно в градуированном режиме:
Проверка входных данных (validateInverseTrigArgument) проверяет только то, что аргументы находятся в диапазоне [-1, 1], который подходит для радиан, но не применим к градусам.
/>
Это код, который является частью класса Evaluator:
fun setRadianMode(isRadian: Boolean) {
isRadianMode = isRadian
}
fun isInRadianMode(): Boolean = isRadianMode
// Validate arguments for inverse trig functions
private fun validateInverseTrigArgument(func: String, argument: String): Boolean {
return try {
val value = symbols.eval(argument)
when (func) {
"asin", "acos" -> value in -1.0..1.0
else -> true
}
} catch (e: Exception) {
false // If evaluation fails, consider it invalid
}
}
private fun convertTrigFunctions(expression: String): String {
val trigFunctions = listOf("sin", "cos", "tan", "cot")
val inverseTrigFunctions = listOf("asin", "acos", "atan", "acot")
var modifiedExpression = expression
// First handle regular trig functions
for (func in trigFunctions) {
val regex = "$func\\(".toRegex()
val matches = regex.findAll(modifiedExpression)
for (match in matches.toList().reversed()) {
val startIndex = match.range.last + 1
val endIndex = try {
findMatchingParenthesis(modifiedExpression, startIndex)
} catch (e: IllegalArgumentException) {
// If no closing parenthesis, treat end of expression as the closing point
modifiedExpression.length
}
val argument = modifiedExpression.substring(startIndex, endIndex)
val convertedArgument = if (!isRadianMode) {
"$func($argument * $PI / 180)"
} else {
"$func($argument)"
}
modifiedExpression = modifiedExpression.replaceRange(match.range.first, endIndex, convertedArgument)
}
}
// Then handle inverse trig functions separately
for (func in inverseTrigFunctions) {
val regex = "$func\\(".toRegex()
val matches = regex.findAll(modifiedExpression)
for (match in matches.toList().reversed()) {
val startIndex = match.range.last + 1
val endIndex = try {
findMatchingParenthesis(modifiedExpression, startIndex)
} catch (e: IllegalArgumentException) {
modifiedExpression.length
}
val argument = modifiedExpression.substring(startIndex, endIndex)
// Convert output of inverse trig function to degrees if in degree mode
val convertedArgument = if (!isRadianMode) {
"($func($argument) * 180 / $PI)"
} else {
"$func($argument)"
}
modifiedExpression = modifiedExpression.replaceRange(match.range.first, endIndex, convertedArgument)
}
}
return modifiedExpression
}
Я использую Javia Arity/Arithmetic для оценки выражений: https://github.com/preda/arithmetic Я попробовал это с математической библиотекой Java, но безуспешно
private fun evaluateInverseTrigFunction(func: String, argument: Double): Double {
val result = when (func) {
"asin" -> Math.asin(argument)
"acos" -> Math.acos(argument)
"atan" -> Math.atan(argument)
else -> throw IllegalArgumentException("Invalid function: $func")
}
// Convert to degrees if not in radian mode
return if (!isRadianMode) result * 180 / Math.PI else result
}
private fun convertTrigFunctions(expression: String): String {
val trigFunctions = listOf("sin", "cos", "tan", "cot")
val inverseTrigFunctions = listOf("asin", "acos", "atan", "acot")
var modifiedExpression = expression
// Handle regular trig functions as before
for (func in trigFunctions) {
val regex = "$func\\(".toRegex()
val matches = regex.findAll(modifiedExpression)
for (match in matches.toList().reversed()) {
val startIndex = match.range.last + 1
val endIndex = try {
findMatchingParenthesis(modifiedExpression, startIndex)
} catch (e: IllegalArgumentException) {
modifiedExpression.length
}
val argument = modifiedExpression.substring(startIndex, endIndex)
val convertedArgument = if (!isRadianMode) {
"$func($argument * $PI / 180)"
} else {
"$func($argument)"
}
modifiedExpression = modifiedExpression.replaceRange(match.range.first, endIndex, convertedArgument)
}
}
// Handle inverse trig functions
for (func in inverseTrigFunctions) {
val regex = "$func\\(([^)]+)\\)".toRegex() // Match function argument inside parentheses
val matches = regex.findAll(modifiedExpression)
for (match in matches.toList().reversed()) {
val argumentStr = match.groupValues[1]
// Evaluate the argument expression as a Double
val argument = symbols.eval(argumentStr)
// Get result from evaluateInverseTrigFunction
val result = evaluateInverseTrigFunction(func, argument)
// Replace original function call with the computed result
modifiedExpression = modifiedExpression.replaceRange(match.range, result.toString())
}
}
return modifiedExpression
}
Обратные триггерные функции: когда ConvertTrigFunctions обнаруживает обратную триггерную функцию (например, asin, acos, atan):
Он извлекает аргумент и оценивает его как Double.
Он вызывает функцию AssessmentInverseTrigFunction, которая вычисляет результат и применяет преобразование степени, если isRadianMode имеет значение false.
Он заменяет исходный вызов функции в выражении вычисленным результатом.
[b]1) Неправильные выходные данные для режима степени:[/b] [list] [*]asin(0.55) должен возвращать примерно [b]33,367[/b] > градусов, но в настоящее время он возвращает [b]0,550[/b]. [*]acos(0,55) должен возвращать примерно [b]56,632[/b] градусов, но в настоящее время он возвращает [b]89,449[/b]. [*]atan(0,55) должен возвращать примерно [b]28,810[/b] градусов, но в настоящее время он возвращает [b]0,502[/b]. [/list] [b]2) Пределы проверки не применяются правильно в градуированном режиме:[/b] [list] Проверка входных данных (validateInverseTrigArgument) проверяет только то, что аргументы находятся в диапазоне [-1, 1], который подходит для радиан, но [b]не применим к градусам[/b]. />[/list] [b]Это код, который является частью класса Evaluator:[/b] [code] fun setRadianMode(isRadian: Boolean) { isRadianMode = isRadian }
fun isInRadianMode(): Boolean = isRadianMode
// Validate arguments for inverse trig functions private fun validateInverseTrigArgument(func: String, argument: String): Boolean { return try { val value = symbols.eval(argument) when (func) { "asin", "acos" -> value in -1.0..1.0 else -> true } } catch (e: Exception) { false // If evaluation fails, consider it invalid } }
private fun convertTrigFunctions(expression: String): String { val trigFunctions = listOf("sin", "cos", "tan", "cot") val inverseTrigFunctions = listOf("asin", "acos", "atan", "acot") var modifiedExpression = expression
// First handle regular trig functions for (func in trigFunctions) { val regex = "$func\\(".toRegex() val matches = regex.findAll(modifiedExpression)
for (match in matches.toList().reversed()) { val startIndex = match.range.last + 1 val endIndex = try { findMatchingParenthesis(modifiedExpression, startIndex) } catch (e: IllegalArgumentException) { // If no closing parenthesis, treat end of expression as the closing point modifiedExpression.length }
val argument = modifiedExpression.substring(startIndex, endIndex)
val convertedArgument = if (!isRadianMode) { "$func($argument * $PI / 180)" } else { "$func($argument)" }
// Then handle inverse trig functions separately for (func in inverseTrigFunctions) { val regex = "$func\\(".toRegex() val matches = regex.findAll(modifiedExpression)
for (match in matches.toList().reversed()) { val startIndex = match.range.last + 1 val endIndex = try { findMatchingParenthesis(modifiedExpression, startIndex) } catch (e: IllegalArgumentException) { modifiedExpression.length }
val argument = modifiedExpression.substring(startIndex, endIndex)
// Convert output of inverse trig function to degrees if in degree mode val convertedArgument = if (!isRadianMode) { "($func($argument) * 180 / $PI)" } else { "$func($argument)" }
return modifiedExpression } [/code] Я использую Javia Arity/Arithmetic для оценки выражений: https://github.com/preda/arithmetic [b]Я попробовал это с математической библиотекой Java, но безуспешно[/b] [code]private fun evaluateInverseTrigFunction(func: String, argument: Double): Double { val result = when (func) { "asin" -> Math.asin(argument) "acos" -> Math.acos(argument) "atan" -> Math.atan(argument) else -> throw IllegalArgumentException("Invalid function: $func") }
// Convert to degrees if not in radian mode return if (!isRadianMode) result * 180 / Math.PI else result }
private fun convertTrigFunctions(expression: String): String { val trigFunctions = listOf("sin", "cos", "tan", "cot") val inverseTrigFunctions = listOf("asin", "acos", "atan", "acot") var modifiedExpression = expression
// Handle regular trig functions as before for (func in trigFunctions) { val regex = "$func\\(".toRegex() val matches = regex.findAll(modifiedExpression)
for (match in matches.toList().reversed()) { val startIndex = match.range.last + 1 val endIndex = try { findMatchingParenthesis(modifiedExpression, startIndex) } catch (e: IllegalArgumentException) { modifiedExpression.length }
val argument = modifiedExpression.substring(startIndex, endIndex)
val convertedArgument = if (!isRadianMode) { "$func($argument * $PI / 180)" } else { "$func($argument)" }
// Handle inverse trig functions for (func in inverseTrigFunctions) { val regex = "$func\\(([^)]+)\\)".toRegex() // Match function argument inside parentheses val matches = regex.findAll(modifiedExpression)
for (match in matches.toList().reversed()) { val argumentStr = match.groupValues[1]
// Evaluate the argument expression as a Double val argument = symbols.eval(argumentStr)
// Get result from evaluateInverseTrigFunction val result = evaluateInverseTrigFunction(func, argument)
// Replace original function call with the computed result modifiedExpression = modifiedExpression.replaceRange(match.range, result.toString()) } }
return modifiedExpression }
[/code] Обратные триггерные функции: когда ConvertTrigFunctions обнаруживает обратную триггерную функцию (например, asin, acos, atan): [list] [*] Он извлекает аргумент и оценивает его как Double. [*]Он вызывает функцию AssessmentInverseTrigFunction, которая вычисляет результат и применяет преобразование степени, если isRadianMode имеет значение false. [*] Он заменяет исходный вызов функции в выражении вычисленным результатом. [/list]
1) Неправильные выходные данные для режима степени:
asin(0.5) должен возвращать 30 градусов, но в настоящее время он возвращает 0,5000063464 .
acos(0.5) должен возвращать 60 градусов, но в настоящее время он возвращает 89,499993654 .
atan(1)...
1) Неправильные выходные данные для режима степени:
asin(0.5) должен возвращать 30 градусов, но в настоящее время он возвращает 0,5000063464 .
acos(0.5) должен возвращать 60 градусов, но в настоящее время он возвращает 89,499993654 .
atan(1)...
азин(0.5) должен вернуть 30 Степени, но в настоящее время он возвращается 0,5000063464 .
acos(0.5) должен вернуться 60 градусы, но в настоящее время он возвращает 89,4999936544 .
Atan (1) должен...
Я пытаюсь соединить или спроецировать 3 изображения с 3 камер с углом обзора 120 градусов, которые были выровнены так, чтобы идеально охватывать угол обзора 360 градусов. Они не перекрываются, поэтому обычные методы сшивания с использованием класса...
Я пытаюсь соединить или спроецировать 3 изображения с 3 камер с углом обзора 120 градусов, которые были выровнены так, чтобы идеально охватывать угол обзора 360 градусов. Они не перекрываются, поэтому обычные методы сшивания с использованием класса...