From 96f2b20a822d3a72aa67a2a3a3bc4409f02e5eb0 Mon Sep 17 00:00:00 2001 From: Shchoholiev Date: Fri, 3 Dec 2021 09:59:42 +0200 Subject: [PATCH] removed boolean from set algebra --- Boolean-Algebra/favicon.png | Bin 613 -> 0 bytes Boolean-Algebra/index.html | 102 ------ Boolean-Algebra/script.js | 598 ------------------------------------ 3 files changed, 700 deletions(-) delete mode 100644 Boolean-Algebra/favicon.png delete mode 100644 Boolean-Algebra/index.html delete mode 100644 Boolean-Algebra/script.js diff --git a/Boolean-Algebra/favicon.png b/Boolean-Algebra/favicon.png deleted file mode 100644 index 7d3037e3f4a5e1f1115e4180530e1a461ebfa0cd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 613 zcmV-r0-F7aP)*fjtK|WJA%Hgi22%jN zS-&x_F!%$2Iv+eLD4g+gqOfUkp|1drYh1Ym@67s*v1a{8S4(k*S-)|qv^xiIBeAPw zGt~y)28<=yZrA81H|@^YG+j{=&owcfu}uKYfUU%AR|5{}&e&Vl$50tuQv6KYCui(U z-n+R307!5t(1j*AA%tbsdjLiN&YiKRS_1a~4z&chWm44FQ4&j~5BTUnMIcJz5gnAp zf_{QNLK)Z=^&UEaGJ31|gq#coQq3*tA6un?phzB5f_1jnE4GFeKcdgmGNH89b(RD8Bo(R%4_ z$0ckf-o?%{@Nc%@8>AhxBl_`aApN1JW6lHVv=t?B?iLkk#~q&MAv;}>;PT#+sNtqT zH8M71U*z@lb%+#4Nh}inR+fNAbLD%X_NqlD z0qVG5A72GkSKb*4A=Hdy|GLgttek`&AKgO)2He9IwO(dCZNFG->WH2|YyANWPc6@D zKE{Epr7^4ihQjO8pMbH_8`;h;r@OtL_Z#yMe - - - - - - - - Boolean Algebra Calculator - - - - - - - -
- -
- - -
- -
- -
-

Values

-
-
-

Value A =

-
-
-
-

Value B =

-
-
-
- -
- -
-

Formulua

-

-
- - -
-
-
-

Result

-
-
-
-
Define variables then write the formula you need to solve
-
-
-
!
-
Negation
-
-
-
*
-
Conjunction
-
-
-
+
-
Disjunction
-
-
-
>
-
Implication
-
-
-
=
-
Equivalence
-
-
-
-
- -
-
-

Step by step

-
-

1.

-
-
-
-
-
- - - - - - - \ No newline at end of file diff --git a/Boolean-Algebra/script.js b/Boolean-Algebra/script.js deleted file mode 100644 index cd69906..0000000 --- a/Boolean-Algebra/script.js +++ /dev/null @@ -1,598 +0,0 @@ -let maxNumOfValues = 26; -let currNumOfValues = 2; - -function AddValue() { - - if (currNumOfValues < 26) { - - let charNum = 65 + currNumOfValues; - currNumOfValues++; - - let delBtn = document.querySelectorAll('#delBtn'); - if (delBtn[delBtn.length - 1]) { - delBtn[delBtn.length - 1].style="display: none;"; - } - - node = document.getElementById('values'); - node.insertAdjacentHTML('beforeend', `
-

Value &#${charNum} =

-
-
`); - - } else { - alert('You have reached a limint of available values'); - } -} - -function DeleteValue(valNum) { - - let valueField = document.querySelector(`#valueField${valNum}`); - valueField.remove(); - currNumOfValues--; - - let delBtn = document.querySelectorAll('#delBtn'); - if (delBtn[delBtn.length - 1]) { - delBtn[delBtn.length - 1].style="display: inline-block;"; - } -} - - -let VALUES = new Set(); -let userValues = new Array(); - -function FetchValues() { - - userValues = new Array(); - - for (let i = 0; i < currNumOfValues; i++) { - - let inputField = document.getElementById(`value${i}`); - let currCharStr = String.fromCharCode(65 + i); - - if (inputField.value === '1' || inputField.value === 'true' || inputField.value === 'True'|| inputField.value === 'TRUE' || inputField.value === 't' || inputField.value === 'T') { - VALUES.add(currCharStr); - userValues.push([currCharStr, true]); - } else if (inputField.value === '0' || inputField.value === 'false' || inputField.value === 'False' || inputField.value === 'FALSE' || inputField.value === 'f' || inputField.value === 'F') { - VALUES.add(currCharStr); - userValues.push([currCharStr, false]); - } - } - - for (const iterator in VALUES) { - console.log(iterator, VALUES[iterator]); - } -} - -let stepByStep = false; - -function Evaluate() { - - FetchValues(); - - let formulaField = document.getElementById('formula'); - - let formulaChraArray = formulaField.value.split(''); - let formulaRPNArray = ConvertCharArrayToRPNArray(formulaChraArray); - let formulaValuesRPNArray = ConvertLettersToValues(formulaRPNArray); - - let result = SolveRPNFormula(formulaValuesRPNArray); - let readableResult = convertToReadableResult(result[0]); - - let resultField = document.getElementById('result'); - resultField.value = readableResult; - - - let stepsNode = document.querySelector('#stepsNode'); - let stepsWrapper = document.querySelector('#stepsWrapper'); - - stepsNode.classList.add('hide'); - stepsWrapper.querySelectorAll('#input-wrap').forEach((element) => { - element.remove(); - }); - - if (stepByStep) { - - stepsNode.classList.remove('hide'); - - let stepsActionsArray = StepByStepRPNFormula(formulaRPNArray); - let stepsResultsArray = result[1]; - - console.log(stepsActionsArray); - console.log(stepsResultsArray); - - for (let i = 0; i < stepsActionsArray.length; i++) { - const action = stepsActionsArray[i]; - const result = stepsResultsArray[i]; - - stepsWrapper.insertAdjacentHTML('beforeend', `
-

${i+1}.

-
-
`); - } - - stepByStep = false; - } -} - -function StepByStep() { - - stepByStep = true; - Evaluate(); -} - - -function Negation(value) { - - if (value != undefined) { return !value; } -} - -function Conjunction(firstValue, secondValue) { - - if (firstValue === true && secondValue === true) { - return true; - } else if (firstValue === false && secondValue === true || firstValue === true && secondValue === false || firstValue === false && secondValue === false) { - return false; - } -} - -function Disjunction(firstValue, secondValue) { - - if (firstValue === true || secondValue === true) { - return true; - } else if (firstValue === false && secondValue === false) { - return false; - } -} - -function Equivalence(firstValue, secondValue) { - - if (firstValue === secondValue) { - return true; - } else if (firstValue !== secondValue) { - return false; - } -} - - - - - - -function ConvertCharArrayToRPNArray(chars) { - - let _values_stack = new Array(); - let _actions_stack = new Array(); - - for (let i = 0; i < chars.length; i++) { - const element = chars[i]; - - if (VALUES.has(element)) { - - _values_stack.push(element); - } else if (OPERATORS.has(element)) { - - while (GetActionPriority(_actions_stack[_actions_stack.length - 1]) >= GetActionPriority(element)) { - - let last = _actions_stack.pop(); - - if (last != '(') { - _values_stack.push(last); - } else { - break; - } - } - - if (_actions_stack[0] == undefined || GetActionPriority(_actions_stack[_actions_stack.length - 1]) < GetActionPriority(element)) { - - _actions_stack.push(element); - } - } else if (BRACKETS.has(element)) { - - if (element == '(') { - - _actions_stack.push(element); - } - - if (element == ')') { - - let _last = _actions_stack.pop(); - - while (_last != '(') { - - _values_stack.push(_last); - _last = _actions_stack.pop(); - } - } - } else { - Error('The programm cant solve given formula. Do you typed everything right? Maybe you forgot to define some value?'); - } - } - - while (_actions_stack[0] != undefined) { - - _values_stack.push(_actions_stack.pop()); - } - - return _values_stack; -} - -function ConvertLettersToValues(RPNArray) { - - let valuesRNPArray = new Array(); - - RPNArray.forEach(element => { - - if (VALUES.has(element)) { - valuesRNPArray.push(GetValueFromIndex(element)); - } else if (element !== '(' || element !== ')') { - valuesRNPArray.push(element); - } - }); - - return valuesRNPArray; -} - -function SolveRPNFormula(valuesRPNArray) { - - let stepByStepResults = new Array(); - - let _stack = new Array(); - - for (let i = 0; i < valuesRPNArray.length; i++) { - const element = valuesRPNArray[i]; - - if (OPERATORS.has(element)) { - - if (element == '!') { - - let _currValue = _stack.pop(); - - let _result = Negation(_currValue); - - _stack.push(_result); - stepByStepResults.push(convertToReadableResult(_result)); - - } else if (element == '*') { - - let _secondValue = _stack.pop(); - let _firstValue = _stack.pop(); - - let _result = Conjunction(_firstValue, _secondValue); - - _stack.push(_result); - stepByStepResults.push(convertToReadableResult(_result)); - - } else if (element == '+') { - - let _secondValue = _stack.pop(); - let _firstValue = _stack.pop(); - - let _result = Disjunction(_firstValue, _secondValue); - - _stack.push(_result); - stepByStepResults.push(convertToReadableResult(_result)); - - } else if (element == '>') { - - let _secondValue = _stack.pop(); - let _firstValue = _stack.pop(); - - let _result = Disjunction(Negation(_firstValue), _secondValue); - - _stack.push(_result); - stepByStepResults.push(convertToReadableResult(_result)); - - } else if (element == '=') { - - let _secondValue = _stack.pop(); - let _firstValue = _stack.pop(); - - let _result = Equivalence(_firstValue, _secondValue); - - _stack.push(_result); - stepByStepResults.push(convertToReadableResult(_result)); - - } - } else { - - _stack.push(element); - } - } - - return [_stack[0], stepByStepResults]; -} - -function StepByStepRPNFormula(RPNArray) { - - let stepsArray = new Array(); - - let _stack = new Array(); - - for (let i = 0; i < RPNArray.length; i++) { - const element = RPNArray[i]; - - if (OPERATORS.has(element)) { - - if (element == '!') { - - let _currValue = _stack.pop(); - - let _result; - - if (_currValue.length <= 2) { - _result = '!'.concat(_currValue); - } else { - _result = '!'.concat('(').concat(_currValue).concat(')'); - } - - _stack.push(_result); - stepsArray.push([_result]); - - } else if (element == '*') { - - let _secondValue = _stack.pop(); - let _firstValue = _stack.pop(); - - let _result; - - let _firstHasExclemMark = Boolean(_firstValue.split('').filter(x => x === '!').length); - let _secondHasExclemMark = Boolean(_secondValue.split('').filter(x => x === '!').length); - - if (_firstValue.length <= 2 && _secondValue.length <= 2) { - _result = _firstValue.concat('*').concat(_secondValue); - } else if (_firstValue.length <= 2 && _secondValue.length > 2) { - - if (_secondHasExclemMark) { - - _result = _firstValue.concat('*').concat(_secondValue); - } else { - _result = - _firstValue.concat('*').concat('(').concat(_secondValue).concat(')'); - } - } else if (_firstValue.length > 2 && _secondValue.length <= 2) { - - if (_firstHasExclemMark) { - - _result = _firstValue.concat('*').concat(_secondValue); - } else { - - _result = '('.concat(_firstValue).concat(')').concat('*').concat(_secondValue); - } - } else if (_firstValue.length > 2 && _secondValue.length > 2) { - - if (_firstHasExclemMark && _secondHasExclemMark) { - - _result = _firstValue.concat('*').concat(_secondValue); - } if (_firstHasExclemMark && !_secondHasExclemMark) { - - _result = _firstValue.concat('*').concat('(').concat(_secondValue).concat(')'); - } else if (!_firstHasExclemMark && _secondHasExclemMark) { - - _result = '('.concat(_firstValue).concat(')').concat('*').concat(_secondValue);; - } else { - - _result = '('.concat(_firstValue).concat(')').concat('*').concat('(').concat(_secondValue).concat(')'); - } - } - - _stack.push(_result); - stepsArray.push([_result]); - - } else if (element == '+') { - - let _secondValue = _stack.pop(); - let _firstValue = _stack.pop(); - - let _result = _firstValue.concat('+').concat(_secondValue); - - _stack.push(_result); - stepsArray.push([_result]); - - } else if (element == '>') { - - let _secondValue = _stack.pop(); - let _firstValue = _stack.pop(); - - let _result = _firstValue.concat('>').concat(_secondValue); - - _stack.push(_result); - stepsArray.push([_result]); - - } else if (element == '=') { - - let _secondValue = _stack.pop(); - let _firstValue = _stack.pop(); - - let _result = _firstValue.concat('=').concat(_secondValue); - - _stack.push(_result); - stepsArray.push([_result]); - } - } else { - - _stack.push(element); - } - } - - return stepsArray; - // return _stack[0]; -} - - - - - -function InputFormulaFotTruthTable() { - - - let _formulaString = prompt('>>> '); - - - if (_formulaString.search('[!,*,+,>,=]') == -1) { - Error('The programm cant solve given formula. Do you typed everything right?'); - } - - - if (_formulaString.match(/[a-z]/g) != null) { - - _formulaString.match(/[a-z]/g).forEach (element => { - TTVALUESNAMES.add(element); - }) - } else { - Error('The programm cant solve given formula. Do you typed everything right?'); - } - - TTVALUESNAMES.forEach(element => { - TTVALUESCONTENTS.push([element]); - }) - - - let _numColumns = TTVALUESNAMES.size; - - let _numRows = Math.pow(2, _numColumns); - - - - let _rowsContent = new Array(); - - for (let r = 0; r < _numRows; r++) { - - _rowsContent.push(new Array()); - - for (let c = 0; c < _numColumns; c++) { - - _rowsContent[r].push(false); - } - } - - - for (let c = 0; c < _numColumns; c++) { - - let _period = Math.pow(2, _numColumns) / Math.pow(2, c+1); - - let _zeros = true; - - for (let r = 0; r < _numRows; r++) { - - if (_zeros) { - _rowsContent[r][c] = false; - TTVALUESCONTENTS[c].push(false); - } - - if (!_zeros) { - _rowsContent[r][c] = true; - TTVALUESCONTENTS[c].push(true); - } - - if ((r + 1) % _period == 0) { - _zeros = !_zeros; - } - } - } - - // console.log(_rowsContent); - // console.log(TTVALUESCONTENTS); - - - - let _formulaCharArray = ConvertFormulaToCharArray(_formulaString); - - let _result = new Array(); - - for (let i = 0; i < _numRows; i++) { - - let _formula_RPN_Array = ConvertCharArrayToRPNArray(_formulaCharArray, i + 1); - _result.push(SolveRPNFormula(_formula_RPN_Array)); - } - // console.log(_result); - _result.forEach(element => { - - if (element == undefined) { - Error('The programm cant solve given formula. Do you typed everything right?'); - } - }); - - ttformula = _formulaString; - numRows = _numRows; - rowsContent = _rowsContent; - truthTable = _result; - - - console.log(''); - for (let r = 0; r < _numRows; r++) { - - console.log(` ${_rowsContent[r].join(', ')} : ${_result[r]}`); - } - console.log(''); - - ClearTruthTableData(); - - ReturnToMenu(); -} - - - - -const OPERATORS = new Set(['!', '*', '+', '>', '=']); -const BRACKETS = new Set(['(', ')']); - -function GetActionPriority(action) { - - if (action == '!') { - return 5; - } else if (action == '*') { - return 4; - } else if (action == '+' || action == '>' || action == '=') { - return 3; - } else if (action == '(') { - return 2; - } else { - return 0; - } -} - -function GetValueFromIndex(valueIndex) { - - for (let i = 0; i < userValues.length; i++) { - const element = userValues[i]; - - if (element[0] == valueIndex) { - return element[1]; - } - } -} - -function convertToReadableResult(unconverted) { - - return unconverted === true ? '1' : '0'; -} - -function Error(errMsg) { - console.log(` [ERROR] ${errMsg}`); -} - -//----------------------------- Check Input --------------------------- - -const symbols = ['0', '1']; -const specialSymbols = ['Backspace', 'ArrowLeft', 'ArrowRight', 'Delete']; - -function checkInputValue(key, value) { - if (value.length < 1 && symbols.indexOf(key) !== -1) { - return true; - } else if (value.length == 1 && specialSymbols.indexOf(key) !== -1) { - return true; - } - else { - return false; - } -} - -const symbols2 = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', - 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', - 'W', 'X', 'Y', 'Z', 'Backspace', 'ArrowLeft', 'ArrowRight', 'Delete', - '>', '=', '+', '*', '!', '(', ')' -]; - -function checkInputProblem(key) { - return (symbols2.indexOf(key) != -1) ? true : false; -} \ No newline at end of file