|
Message Closed
modified 19-May-23 21:28pm.
|
|
|
|
|
polcott wrote: Whether or not these insights apply to the actual halting problem is a next level review that must be done by a qualified computer scientist.
The code you have provided is a demonstration of something that has already been demonstrated mathematically. Doesn't matter how you phrase your posts that remains true.
Lets say you create a interpreter which changes the context in which the problem runs. For example it halts every single time a specific instruction is called. Certainly provable that it halts then. But that is a different problem than the one you posted.
So your choices are
1. Find your own problem and prove anything you want about it. You must fully define the problem space.
2. Find a way to invalidate the existing Turing proof using the context in which it was presented. You do not get to change that context - if you want to change the context then see item #1.
Note that step #1 even being fully correct will say nothing about the Turing proof.
|
|
|
|
|
Message Closed
modified 19-May-23 21:27pm.
|
|
|
|
|
polcott wrote: cannot possibly terminate normally.
Nigel Molesworth* wrote: As any fule kno.
*The curse of St. Custard's
|
|
|
|
|
Message Closed
modified 19-May-23 21:26pm.
|
|
|
|
|
polcott wrote: If I was actually wrong someone could point out a mistake.
I can't speak for anyone else but I am certainly not going to attempt to teach you an entire class on Turing Machine mathematics.
And I already suggested that you take exactly that sort of class.
I found one that teaches it. I know there are others.
Models of Computation[^]
|
|
|
|
|
Latest update: the bug is gone after I run cmd console, instead of the new Terminal console. Case closed. Thanks everybody for checking and testing.
I found a cout bug with Visual C++ 2022 on Windows 11. VC++ 2019 does not have this bug. When I try to debug, the problem goes away. I have produced a small repo that reproduces the issue. Please help me check so that I can report this bug to Microsoft. Thanks.
modified 12-May-23 8:10am.
|
|
|
|
|
I cannot confirm the bug. Everything works in the order expected.
Microsoft (R) C/C++ Optimizing Compiler Version 19.35.32217.1 for x86
on
Windows 11 Pro
Version 22H2 (OS Build 22621.1555)
|
|
|
|
|
Thanks. Your Visual C++ and Windows edition is the same as mine. Did you run it a few times? The bug has 50% chance of reproducing when run normally (meaning not debugging).
|
|
|
|
|
Only about 30 times, and it never happened even once.
|
|
|
|
|
The bug is gone after I followed Richard's suggestion to run the old cmd console. Thanks for testing.
|
|
|
|
|
I was using CMD Prompt and Powershell in Terminal with no issues at all, in both Debug and Release builds.
|
|
|
|
|
It looks like nobody is encountering this issue except me. Thanks again. You can stop testing.
|
|
|
|
|
Its working fine here on Windows 10, VS 17.5.5, so I would suspect the Windows 11 terminal - can you try running it in a cmd.exe window instead?
|
|
|
|
|
My c:\windows\system32\cmd.exe is already the new Windows 11 terminal. I am not sure where the old cmd.exe is.
|
|
|
|
|
If the Terminal in Windows 11 is the same as the one in 10 then you can configure it to run cmd, Powershell, Linux shell etc.
|
|
|
|
|
Thanks for your suggestion. I have configured it to run the normal cmd window by right-clicking the tab area and choosing "Settings" in the pop-up menu and selecting accordingly. The bug is gone.
|
|
|
|
|
Very interesting. What program was it running before your change?
|
|
|
|
|
Before my change to the old normal cmd, the new Terminal console has a tabbed interface and was slower than cmd window. I did not change my code. Now it is running fine.
|
|
|
|
|
Mine also has a tabbed interface, so I have three tabs: cmd , PowerShell and Linux under WSL. It seems just as fast as anything else. I can only assume there is another interface that is the default in the 11 version. Unfortunately (or maybe not) my PC does not support Windows 11.
|
|
|
|
|
Richard MacCutchan wrote: Terminal in Windows
I am not familiar with that. Presumably it is the following which one must install specifically, at least in Windows 10?
An overview on Windows Terminal | Microsoft Learn[^]
So you use that normally? I am curious why do you consider that ideal rather than going directly to either cmd or a linux shell?
|
|
|
|
|
jschell wrote: why do you consider that ideal rather than going directly to either cmd or a linux shell? I did not claim it is ideal, it is just another tool that I find useful at times. I run cmd, Powershell and Linux in "normal" windows also.
|
|
|
|
|
Using the cmd.exe window, the bug is gone.
|
|
|
|
|
I am trying to play an mp3 file from a WinAPI/C++ application. I'm using 32-bit MinGW on Windows 10.
I found an example program which uses the MCI (winmm) interface to play the file; I found an example command-line program which implements this using mciSendString() calls...
I had some problems handling paths to the mp3 file, and *thought* I had fixed it by converting the paths to 8.3 short format... the command-line program plays the files just fine, but when I import exactly the same code into my WinAPI dialog-box application, although the MCI functions all return success, no sound plays...
Does anyone have any idea what is missing here?? Or does this library just not work from a Windows dialog app?
Here's the code:
{
static char short_str[MAX_WAVE_FILE_LEN+1] = "" ;
CMP3_MCI MyMP3;
int result = GetShortPathName (wave_name, short_str, MAX_WAVE_FILE_LEN);
syslog("short: %d: [%s]\n", result, short_str);
DWORD lerror = MyMP3.Load(short_str);
DWORD serror = MyMP3.Play();
syslog("MCI: Load: %08X, Play: %08X\n", lerror, serror);
}
And here are the load and play functions from his MCI class:
inline MCIERROR Load()
{
std::string szCommand = "open \"" + GetFileName() + "\" type mpegvideo alias " + GetFileName();
return mciSendString(szCommand.c_str(), NULL, 0, 0);
}
inline MCIERROR Load(char *szFileName)
{
m_szFileName = szFileName;
return Load();
}
inline MCIERROR Play()
{
std::string szCommand = "play " + GetFileName() + " from 0";
return mciSendString(szCommand.c_str(), NULL, 0, 0);
}
|
|
|
|
|
This is a Simple C++ DirectShow MP3 Player Class for native C++ and .NET.
This is an example on how to use the Mp3 class.
<h1>include "Mp3.h"</h1>
void main()
{
::CoInitialize(NULL);
std::wcout<<L"Enter the MP3 path: ";
std::wstring path;
getline(wcin, path);
std::wcout<<path<<std::endl;
Mp3 mp3;
int status = 0;
if(mp3.Load(path.c_str()))
{
status = SV_LOADED;
}
else {
}
if(mp3.Play())
{
status = SV_PLAYING;
}
else {
}
if(mp3.Stop())
{
status = SV_STOPPED;
}
else {
}
::CoUninitialize();
}
modified 12-May-23 8:19am.
|
|
|
|